首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MongoDB中的慢速正则表达式查询

MongoDB中的慢速正则表达式查询
EN

Stack Overflow用户
提问于 2012-04-09 20:31:05
回答 1查看 1.7K关注 0票数 5

我在一个集合中有150万个文档,其中有索引的"name“字段。像db.things.find({name: /^foo/i})这样的查询大约需要5秒,速度非常慢。具有相同记录的类似MySQL表在不到10 ms内执行SELECT * FROM things WHERE name LIKE 'foo%'

蒙戈解释道:

代码语言:javascript
复制
db.things.find({name: /^foo/i}).limit(10).explain()
{
    "cursor" : "BtreeCursor name_1 multi",
    "nscanned" : 325730,
    "nscannedObjects" : 10,
    "n" : 10,
    "millis" : 4758,
    "nYields" : 89,
    "nChunkSkips" : 0,
    "isMultiKey" : false,
    "indexOnly" : false,
    "indexBounds" : {
        "name" : [
            [
                "",
                {

                }
            ],
            [
                /^foo/i,
                /^foo/i
            ]
        ]
    }
}

那么,regexp查询在mongo中是慢的还是我做错了呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-04-10 03:38:10

不区分大小写的regex搜索将是缓慢的,因为它不能有效地利用索引。如果只使用该字段进行搜索,则应考虑以所有小写形式存储文本,并使用区分大小写的正则表达式进行搜索。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10079444

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档