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"}}) 优化正则表达式查询
这里面使用正则表达式有两点必要注意: 正则表达式中使用变量.必定要使用eval将组合的字符串进行转换,不能直接将字符串拼接后传入给表达式.否则没有报错信息,只是结果为空!实例如下: var name=eval("/" + 变量值key +"/i"); 以下是模糊查询包括title关键词,且不区分大小写: title:eval("/"+title+"/i") // 等同于 title:{$regex:title,$Option:"$i"} 如您还有不明确的可以在下面与我留言或是与我探讨QQ群308855039,我们一起飞! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |