课程表

MongoDB 基础教程

MongoDB 高级教程

工具箱
速查手册

MongoDB 正则表达式

当前位置:免费教程 » 数据库/运维 » MongoDB

正则表达式是使用单个字符串来描述、匹配一系列符合某个句法规则的字符串。

许多程序设计语言都支持利用正则表达式进行字符串操作。

MongoDB 使用 $regex 操作符来设置匹配字符串的正则表达式。

MongoDB使用PCRE (Perl Compatible Regular Expression) 作为正则表达式语言。

不同于全文检索,我们使用正则表达式不需要做任何配置。

考虑以下 posts 集合的文档结构,该文档包含了文章内容和标签:

  1. {
  2. "post_text": "enjoy the mongodb articles on tutorialspoint",
  3. "tags": [
  4. "mongodb",
  5. "tutorialspoint"
  6. ]
  7. }

使用正则表达式

以下命令使用正则表达式查找包含 w3xue.com 字符串的文章:

  1. >db.posts.find({post_text:{$regex:"w3xue.com"}})

以上查询也可以写为:

  1. >db.posts.find({post_text:/w3xue.com/})

不区分大小写的正则表达式

如果检索需要不区分大小写,我们可以设置 $options 为 $i。

以下命令将查找不区分大小写的字符串 w3xue.com:

  1. >db.posts.find({post_text:{$regex:"w3xue.com",$options:"$i"}})

集合中会返回所有包含字符串 w3xue.com 的数据,且不区分大小写:

  1. {
  2. "_id" : ObjectId("53493d37d852429c10000004"),
  3. "post_text" : "hey! this is my post on W3Cschool.cc",
  4. "tags" : [ "tutorialspoint" ]
  5. }

数组元素使用正则表达式

我们还可以在数组字段中使用正则表达式来查找内容。 这在标签的实现上非常有用,如果你需要查找包含以 tutorial 开头的标签数据(tutorial 或 tutorials 或 tutorialpoint 或 tutorialphp), 你可以使用以下代码:

  1. >db.posts.find({tags:{$regex:"tutorial"}})

优化正则表达式查询

  • 如果你的文档中字段设置了索引,那么使用索引相比于正则表达式匹配查找所有的数据查询速度更快。

  • 如果正则表达式是前缀表达式,所有匹配的数据将以指定的前缀字符串为开始。例如: 如果正则表达式为 ^tut ,查询语句将查找以 tut 为开头的字符串。

这里面使用正则表达式有两点需要注意:

正则表达式中使用变量。一定要使用eval将组合的字符串进行转换,不能直接将字符串拼接后传入给表达式。否则没有报错信息,只是结果为空!实例如下:

  1. var name=eval("/" + 变量值key +"/i");

以下是模糊查询包含title关键词, 且不区分大小写:

  1. title:eval("/"+title+"/i") // 等同于 title:{$regex:title,$Option:"$i"}
转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号