現在、準大規模な更新に使用している OR クエリがあります。基本的に、私のコレクションは 2 つのデータ セットに分割されます。
1 つのメイン リポジトリとメイン リポジトリの 1 つのサブセット。これは、データの小さなサブセットをすばやく検索できるようにするためです。
しかし、サブセットにプルするために作成したクエリがタイムアウトしていることがわかりました..説明を見ると、実際には2つのクエリが発生しているように見えます.
PRIMARY> var date = new Date(2012,05,01);
PRIMARY> db.col.find(
{"$or":[
{"date":{"$gt":date}},
{"keywords":{"$in":["Help","Support"]}}
]}).explain();
これにより、次が生成されます。
{
"clauses" : [
{
"cursor" : "BtreeCursor ldate_-1",
"nscanned" : 1493872,
"nscannedObjects" : 1493872,
"n" : 1493872,
"millis" : 1035194,
"nYields" : 3396,
"nChunkSkips" : 0,
"isMultiKey" : false,
"indexOnly" : false,
"indexBounds" : {
"ldate" : [
[
ISODate("292278995-01--2147483647T07:12:56.808Z"),
ISODate("2012-06-01T07:00:00Z")
]
]
}
},
{
"cursor" : "BtreeCursor keywords_1 multi",
"nscanned" : 88526,
"nscannedObjects" : 88526,
"n" : 2515,
"millis" : 1071902,
"nYields" : 56,
"nChunkSkips" : 0,
"isMultiKey" : false,
"indexOnly" : false,
"indexBounds" : {
"keywords" : [
[
"Help",
"Help"
],
[
"Support",
"Support"
]
]
}
}
],
"nscanned" : 1582398,
"nscannedObjects" : 1582398,
"n" : 1496387,
"millis" : 1071902
}
これを高速化するために、より良いインデックスを作成できるものはありますか? ゆっくりする方法のようです...
お早めにどうぞ!