Я создавал свое первое приложение с помощью MongoDB. Создал индекс для поля и попытался найти запрос с параметром $regex, запущенным в оболочке
> db.foo.find({A:{$regex:'BLABLA!25500[0-9]'}}).explain()
{
"cursor" : "BtreeCursor A_1 multi",
"nscanned" : 500001,
"nscannedObjects" : 10,
"n" : 10,
"millis" : 956,
"nYields" : 0,
"nChunkSkips" : 0,
"isMultiKey" : false,
"indexOnly" : false,
"indexBounds" : {
"A" : [
[
"",
{
}
],
[
/BLABLA!25500[0-9]/,
/BLABLA!25500[0-9]/
]
]
}
}
Это очень странно, потому что, когда я запускаю тот же запрос, но без индекса в коллекции, производительность намного лучше.
> db.foo.find({A:{$regex:'BLABLA!25500[0-9]'}}).explain()
{
"cursor" : "BasicCursor",
"nscanned" : 500002,
"nscannedObjects" : 500002,
"n" : 10,
"millis" : 531,
"nYields" : 0,
"nChunkSkips" : 0,
"isMultiKey" : false,
"indexOnly" : false,
"indexBounds" : {
}
}
Очевидно, что поиск в поле с индексом без регулярного выражения работает намного быстрее (т.е. поиск документа с постоянным полем), но я действительно заинтересован в причине такого поведения.