如何改写MongoDB查询,使其支持正则表达式匹配?
- 内容介绍
- 文章标签
- 相关推荐
本文共计820个文字,预计阅读时间需要4分钟。
某日,监控到mongo数据库CPU使用率过高,查看后发现是由以下语句频繁触发:db.example_collection.find({ idField: {$regex: 123456789012345678}, dateField: {$regex: 2019/10/10}})常见。
某一天,监控到mongo数据库cpu使用率高了很多,查了一下,发现是下面这种语句引起的:
db.example_collection.find({ "idField" : { "$regex" : "123456789012345678" } , "dateField" : { "$regex" : "2019/10/10" }})
通常,遇到这种情况,我第一反应是缺少相关字段的索引,导致每执行一次这种语句都会全表扫描一次。
但是我用explain( )语句分析了下,发现上面所涉及的两个字段idField、dateField是有索引的,并且该语句也是有使用到索引的。
本文共计820个文字,预计阅读时间需要4分钟。
某日,监控到mongo数据库CPU使用率过高,查看后发现是由以下语句频繁触发:db.example_collection.find({ idField: {$regex: 123456789012345678}, dateField: {$regex: 2019/10/10}})常见。
某一天,监控到mongo数据库cpu使用率高了很多,查了一下,发现是下面这种语句引起的:
db.example_collection.find({ "idField" : { "$regex" : "123456789012345678" } , "dateField" : { "$regex" : "2019/10/10" }})
通常,遇到这种情况,我第一反应是缺少相关字段的索引,导致每执行一次这种语句都会全表扫描一次。
但是我用explain( )语句分析了下,发现上面所涉及的两个字段idField、dateField是有索引的,并且该语句也是有使用到索引的。

