MongoDB模糊查询作用和语法是什么?模糊查询示例分析
Admin 2021-05-15 群英技术资讯 1379 次浏览
我们在使用MongoDB查询时,模糊查询是比较常见用和实用,因此大家要掌握MongoDB模糊查询操作。为了让大家对MongoDB模糊查询有更深的认识,这篇文章就给大家介绍一下关于MongoDB模糊查询的操作,下面就跟随小编一起来看看吧。
1.作用与语法描述
作用: 正则表达式是使用指定字符串来描述、匹配一系列符合某个句法规则的字符串。许多程序设计语言都支持利用正则表达式进行字符串操作。MongoDB 使用 $regex 操作符来设置匹配字符串的正则表达式。
语法一
{ <field>: { $regex: /pattern/, $options: '<options>' } }
{ <field>: { $regex: 'pattern', $options: '<options>' } }
{ <field>: { $regex: /pattern/<options> } }
语法二
{ <field>: /pattern/<options> }
2.案例演示
假设MongoDB中存放了我们OrderService服务的消息信息,其数据如下:
(以下为演示所用到的9个文档)
{
"_id" : ObjectId("5d305b1c4857fc49c0c14c81"),
"order" : "QQ00001",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"> <Head>ERR</Head><ERROR>重复下单</ERROR></Response>\""
},
{
"_id" : ObjectId("5d305b3b4857fc49c0c14c82"),
"order" : "QQ00001",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"> <Head>ERR</Head><ERROR>重复下单</ERROR></Response>\""
},
{
"_id" : ObjectId("5d305b404857fc49c0c14c83"),
"order" : "QQ00002",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"> <Head>ERR</Head><ERROR>重复下单</ERROR></Response>\""
},
{
"_id" : ObjectId("5d305b454857fc49c0c14c84"),
"order" : "QQ00002",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"> <Head>ERR</Head><ERROR>重复下单</ERROR></Response>\""
},
{
"_id" : ObjectId("5d305b4b4857fc49c0c14c85"),
"order" : "QQ00003",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"> <Head>ERR</Head><ERROR>重复下单</ERROR></Response>\""
},
{
"_id" : ObjectId("5d305b4f4857fc49c0c14c86"),
"order" : "QQ00003",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"> <Head>ERR</Head><ERROR>重复下单</ERROR></Response>\""
},
{
"_id" : ObjectId("5d305bb74857fc49c0c14c87"),
"order" : "QQ00003",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"><Head>OK</Head><Body><OrderResponse filter_mmm=\\\"2\\\" destcity=\\\"shenzheng\\\" origincode=\\\"QQ0003\\\" />
</Body></Response>\""
},
{
"_id" : ObjectId("5d305bd14857fc49c0c14c88"),
"order" : "QQ00002",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"><Head>OK</Head><Body><OrderResponse filter_mmm=\\\"2\\\" destcity=\\\"zhongshan\\\" origincode=\\\"QQ0002\\\" />
</Body></Response>\""
},
{
"_id" : ObjectId("5d305be94857fc49c0c14c89"),
"order" : "QQ00001",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"><Head>OK</Head><Body><OrderResponse filter_mmm=\\\"2\\\" destcity=\\\"zhongshan\\\" origincode=\\\"QQ0001\\\" />
</Body></Response>\"" }
需求: 查询 data 字段 含有 字符 <Head>OK</Head>的文档
执行代码如下:
db.dbtestregex.find({data:{ $regex:/<Head>OK<\/Head>/}})
查询代码中的 \ 为转移符,以下查询语句也是如此。
返回结果如下:
{
"_id" : ObjectId("5d305bb74857fc49c0c14c87"),
"order" : "QQ00003",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"><Head>OK</Head><Body><OrderResponse filter_mmm=\\\"2\\\" destcity=\\\"shenzheng\\\" origincode=\\\"QQ0003\\\" />
</Body></Response>\""
},
{
"_id" : ObjectId("5d305bd14857fc49c0c14c88"),
"order" : "QQ00002",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"><Head>OK</Head><Body><OrderResponse filter_mmm=\\\"2\\\" destcity=\\\"zhongshan\\\" origincode=\\\"QQ0002\\\" />
</Body></Response>\""
},
{
"_id" : ObjectId("5d305be94857fc49c0c14c89"),
"order" : "QQ00001",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"><Head>OK</Head><Body><OrderResponse filter_mmm=\\\"2\\\" destcity=\\\"zhongshan\\\" origincode=\\\"QQ0001\\\" />
</Body></Response>\"" }
上面的查询命令也可以改写成:
db.dbtestregex.find({data:/<Head>OK<\/Head>/})
其查询结果是一样的,如下:
{
"_id" : ObjectId("5d305bb74857fc49c0c14c87"),
"order" : "QQ00003",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"><Head>OK</Head><Body><OrderResponse filter_mmm=\\\"2\\\" destcity=\\\"shenzheng\\\" origincode=\\\"QQ0003\\\" />
</Body></Response>\""
},
{
"_id" : ObjectId("5d305bd14857fc49c0c14c88"),
"order" : "QQ00002",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"><Head>OK</Head><Body><OrderResponse filter_mmm=\\\"2\\\" destcity=\\\"zhongshan\\\" origincode=\\\"QQ0002\\\" />
</Body></Response>\""
},
{
"_id" : ObjectId("5d305be94857fc49c0c14c89"),
"order" : "QQ00001",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"><Head>OK</Head><Body><OrderResponse filter_mmm=\\\"2\\\" destcity=\\\"zhongshan\\\" origincode=\\\"QQ0001\\\" />
</Body></Response>\"" }
还可以写成:
db.dbtestregex.find({data:{ $regex:'<Head>OK<\/Head>'}})
其实现功能一样。
3.类关系型数据库中的 not like 功能实现
反向查询虽然不常见,但也是我们DBA必须的。下面我们做一个案例演示,看看在MongoDB中,怎么实现not like 功能的查询。
需求 查询data 字段中不含 <Head>OK</Head>的文档
执行脚本如下:
db.dbtestregex.find({data:{ $not: /<Head>OK<\/Head>/ }})
返回的文档如下;
{
"_id" : ObjectId("5d305b1c4857fc49c0c14c81"),
"order" : "QQ00001",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"> <Head>ERR</Head><ERROR>重复下单</ERROR></Response>\""
},
{
"_id" : ObjectId("5d305b3b4857fc49c0c14c82"),
"order" : "QQ00001",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"> <Head>ERR</Head><ERROR>重复下单</ERROR></Response>\""
},
{
"_id" : ObjectId("5d305b404857fc49c0c14c83"),
"order" : "QQ00002",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"> <Head>ERR</Head><ERROR>重复下单</ERROR></Response>\""
},
{
"_id" : ObjectId("5d305b454857fc49c0c14c84"),
"order" : "QQ00002",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"> <Head>ERR</Head><ERROR>重复下单</ERROR></Response>\""
},
{
"_id" : ObjectId("5d305b4b4857fc49c0c14c85"),
"order" : "QQ00003",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"> <Head>ERR</Head><ERROR>重复下单</ERROR></Response>\""
},
{
"_id" : ObjectId("5d305b4f4857fc49c0c14c86"),
"order" : "QQ00003",
"data" : "\"<?xml version='1.0' encoding='UTF-8'?><Response service=\\\"OrderService\\\"><Head>ERR</Head><ERROR>重复下单</ERROR></Response>\"" }
总结
关于MongoDB模糊查询的操作就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。想要看更多MongoDB模糊查询的内容,可以关注其他相关文章。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
mongodb中可以使用find()方法查询文档,语法格式为db.collection.find(query,projection)。
MongoDB 概念解析 不管我们学习什么数据库都应该学习其中的基础概念,在mongodb中基本的概念是文档、集合、数据库,下面我们挨个介绍。 下表将帮助您更容易理解Mongo中的一些概念: SQL术语/概念 MongoDB术语/概念 解释/说明 database database 数据库 table collection 数据库表/集合 row document 数据记录行/文档 column field 数..
本篇文章来给各位小伙伴说说MongoDB之group参数的使用内容,我们会先给出一组测试数据,然后练习分组的基本使用。如果你感兴趣的话随小编来了解了解吧!
mongodb多表联查的方法:1、首先用from关联主从表名;2、用as查询结果名;3、用Aggregation进行多条件查询;4、查询结果赋给results;5、用print()输出查询结果。
MongoDB 查询分析 MongoDB 查询分析可以确保我们所建立的索引是否有效,是查询语句性能分析的重要工具。 MongoDB 查询分析常用函数有:explain() 和 hint()。 使用 explain() explain 操作提供了查询信息,使用索引及查询统计等。有利于我们对索引的优化。 接下来我们在 users 集合中创建 gender 和 user_name 的索引: >db.users.ensureInde..
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008