MongoDB日期范围查询优化

4
我需要找到在日期范围内或与其重叠的项目。
首先,我尝试了一个简单的$nor查询。
db.collection.find({
    $nor: [{
        "start.date": { $lt: start },
        "end.date": { $lt: start }
    }, {
        "start.date": { $gte: end },
        "end.date": { $gte: end }
    }]
});

并在两个日期字段上设置索引

db.collection.ensureIndex({"start.date": 1, "end.date": 1});

但查询时不会使用索引

"cursor": "BasicCursor",
"isMultiKey": false,
"n": 2,
"nscannedObjects": 100000,
"nscanned": 100000,
"nscannedObjectsAllPlans": 100000,
"nscannedAllPlans": 100000,
"scanAndOrder": false,
"indexOnly": false,
"nYields": 781,
"nChunkSkips": 0,
"millis": 151,
"allPlans": [
  {
    "cursor": "BasicCursor",
    "isMultiKey": false,
    "n": 2,
    "nscannedObjects": 100000,
    "nscanned": 100000,
    "scanAndOrder": false,
    "indexOnly": false,
    "nChunkSkips": 0
  }
],
"type": "COLLSCAN",

我尝试过的另一种方法是使用相同索引的$or

db.collection.find({
    $or: [{
        "start.date": start,
        "end.date": end
    }, {
        "start.date": { $lt: start },
        "end.date": { $lt: end, $gt: start },
    }, {
        "start.date": { $gt: start, $lt: end },
        "end.date": { $gt: end }
    }, {
        "start.date": { $gt: start },
        "end.date": { $lt: end }
    }, {
        "start.date": { $lt: start },
        "end.date": { $gt: end }
    }]
});

它将使用查询索引,但$nor更快。

是否有一种优化查询的方法或者可以在$nor上使用索引(这样做也有意义吗?)

1个回答

5
您正在搜索在end之前任何地方开始并在start之后任何地方结束的项目(类似于您使用nor表达的方式,只是稍微简单一些):
db.collection.find({
    "start.date": { $lt: end },
    "end.date": { $gt: start }
});

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接