MongoDB 正则表达式

MongoDB 正则表达式,第1张

概述介绍《MongoDB 正则表达式》开发教程,希望对您有用。

《MongoDB 正则表达式》要点:
本文介绍了MongoDB 正则表达式,希望对您有用。如果有疑问,可以联系我们。

欢迎参与《MongoDB 正则表达式》讨论,分享您的想法,内存溢出PHP学院为您提供专业教程。

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

许多法式设计语言都支持利用正则表达式进行字符串 *** 作.

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

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

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

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

{

"post_text": "enjoy the mongodb articles on tutorialspoint",

"Tags": [

"mongodb",

"tutorialspoint"

]}

使用正则表达式

以下命令使用正则表达式查找包括 w3cschool.cc 字符串的文章:

>db.posts.find({post_text:{$regex:"w3cschool.cc"}})

以上查询也可以写为:

>db.posts.find({post_text:/w3cschool.cc/})

不区分年夜小写的正则表达式

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

以下命令将查找不区分年夜小写的字符串 w3cschool.cc:

>db.posts.find({post_text:{$regex:"w3cschool.cc",$options:"$i"}})

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

{

"_ID" : ObjectID("53493d37d852429c10000004"),

"post_text" : "hey! this is my post on W3Cschool.cc",

"Tags" : [ "tutorialspoint" ]}

数组元素使用正则表达式

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

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

优化正则表达式查询

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

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

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

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

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

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

Title:eval("/"+Title+"/i") // 等同于 Title:{$regex:Title,$Option:"$i"}

如您还有不明确的可以在下面与我留言或是与我探讨QQ群308855039,我们一起飞!

总结

以上是内存溢出为你收集整理的MongoDB 正则表达式全部内容,希望文章能够帮你解决MongoDB 正则表达式所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1154276.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存