MongoDB
 sql >> Teknologi Basis Data >  >> NoSQL >> MongoDB

(Bagaimana) dapat agregat() memecahkan indeks?

Saya menduga bahwa masalahnya bukanlah agregasi akan merusak indeks, tetapi agregasi tidak menggunakan indeks dan akan melakukan pemindaian koleksi.

Agregasi dapat memanfaatkan indeks jika ada $ pertandingan dan/atau $sort tahapan ditempatkan di awal pipa. Agregasi ini hanya satu $group tahap, yang berarti seluruh koleksi perlu diulang untuk menghitung hitungan.

Saya memberikan contoh sederhana di bawah ini yang menunjukkan agregasi melakukan pemindaian koleksi, bahkan ketika bidang array diindeks.

> 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. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Metode $push saya di Mongoose tidak berfungsi dengan baik

  2. Berapa ukuran maksimum untuk GridFS di MongoDB?

  3. Bigbluebutton setup html5 dev client login ke meeting dengan join api call respon html kosong

  4. tidak dapat mengambil data dari sudut http

  5. Bagaimana cara memfilter untuk mengembalikan subset dari skema luwak?