sql >> Database >  >> NoSQL >> MongoDB

(Hoe) kan aggregatie() een index breken?

Ik vermoed dat het probleem niet was dat de aggregatie een index zou breken, maar dat de aggregatie geen indexen gebruikte en een collectiescan zou uitvoeren.

Aggregaties kunnen profiteren van indexen als er $ match en/of $sort fasen geplaatst aan het begin van een pijpleiding. Deze aggregatie is slechts een enkele $group stadium, wat betekent dat de hele verzameling moet worden herhaald om de telling te berekenen.

Ik heb hieronder een eenvoudig voorbeeld gegeven van de aggregatie die een collectiescan uitvoert, zelfs wanneer het arrayveld is geïndexeerd.

> db.foo.insert({ "x" : [ 1, 2 ] } )
> db.foo.insert({ "x" : [ 1 ] } )
> db.foo.createIndex({ "x" : 1 } )
...

> db.foo.aggregate([ { $group: { _id: null, cnt: { $sum : { $size: "$x" } } } } ] )
{ "_id" : null, "cnt" : 3 }

// Results of a .explain() - see 'winningPlan' below
> db.foo.explain(true).aggregate([ { $group: { _id: null, cnt: { $sum : { $size: "$x" } } } } ] )
{
    "stages" : [
        {
            "$cursor" : {
                "query" : {

                },
                "fields" : {
                    "x" : 1,
                    "_id" : 0
                },
                "queryPlanner" : {
                    "plannerVersion" : 1,
                    "namespace" : "stack.foo",
                    "indexFilterSet" : false,
                    "parsedQuery" : {

                    },
                    "winningPlan" : {
                        "stage" : "COLLSCAN",
                        "direction" : "forward"
                    },
                    "rejectedPlans" : [ ]
                },
                "executionStats" : {
                    "executionSuccess" : true,
                    "nReturned" : 2,
                    "executionTimeMillis" : 0,
                    "totalKeysExamined" : 0,
                    "totalDocsExamined" : 2,
                    "executionStages" : {
                        "stage" : "COLLSCAN",
                        "nReturned" : 2,
                        "executionTimeMillisEstimate" : 0,
                        "works" : 4,
                        "advanced" : 2,
                        "needTime" : 1,
                        "needYield" : 0,
                        "saveState" : 1,
                        "restoreState" : 1,
                        "isEOF" : 1,
                        "invalidates" : 0,
                        "direction" : "forward",
                        "docsExamined" : 2
                    },
                    "allPlansExecution" : [ ]
                }
            }
        },
        {
            "$group" : {
                "_id" : {
                    "$const" : null
                },
                "cnt" : {
                    "$sum" : {
                        "$size" : [
                            "$x"
                        ]
                    }
                }
            }
        }
    ],
    "ok" : 1,
    ...
}



  1. Hoe start je een mongodb-shell in een docker-container?

  2. MongoDB C# voor elk BsonElement

  3. MongoDB extraheert waarden uit BasicDBObject (Java)

  4. Wat doe ik verkeerd bij het manipuleren van gegevens in Meteor/MongoDB?