如何改写MongoDB查询,使其支持正则表达式匹配?

2026-03-30 09:590阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计820个文字,预计阅读时间需要4分钟。

如何改写MongoDB查询,使其支持正则表达式匹配?

某日,监控到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分钟。

如何改写MongoDB查询,使其支持正则表达式匹配?

某日,监控到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是有索引的,并且该语句也是有使用到索引的。

阅读全文
标签:一次