- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章MongoDB模糊查询操作案例详解(类关系型数据库的 like 和 not like)由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
1.作用与语法描述 。
作用: 正则表达式是使用指定字符串来描述、匹配一系列符合某个句法规则的字符串。许多程序设计语言都支持利用正则表达式进行字符串操作。MongoDB 使用 $regex 操作符来设置匹配字符串的正则表达式.
语法一 。
1
2
3
|
{ <field>: { $regex: /pattern/, $options:
'<options>'
} }
{ <field>: { $regex:
'pattern'
, $options:
'<options>'
} }
{ <field>: { $regex: /pattern/<options> } }
|
语法二 。
1
|
{ <field>: /pattern/<options> }
|
2.案例演示 。
假设MongoDB中存放了我们OrderService服务的消息信息,其数据如下:
(以下为演示所用到的9个文档) 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
{
"_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>的文档 。
执行代码如下:
1
|
db.dbtestregex.find({data:{ $regex:/<Head>OK<\/Head>/}})
|
查询代码中的 \ 为转移符,以下查询语句也是如此.
返回结果如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
{
"_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>\""
}
|
上面的查询命令也可以改写成:
。
1
|
db.dbtestregex.find({data:/<Head>OK<\/Head>/})
|
其查询结果是一样的,如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
{
"_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>的文档 。
执行脚本如下:
1
|
db.dbtestregex.find({data:{ $
not
: /<Head>OK<\/Head>/ }})
|
返回的文档如下,
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
{
"_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>\""
}
|
更多内容可参照官方文档 https://docs.mongodb.com/manual/reference/operator/query/regex/#op._S_regex 。
总结 。
以上所述是小编给大家介绍的MongoDB模糊查询操作案例详解(类关系型数据库的 like 和 not like),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我网站的支持! 如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢! 。
原文链接:https://www.cnblogs.com/xuliuzai/archive/2019/07/19/11209688.html 。
最后此篇关于MongoDB模糊查询操作案例详解(类关系型数据库的 like 和 not like)的文章就讲到这里了,如果你想了解更多关于MongoDB模糊查询操作案例详解(类关系型数据库的 like 和 not like)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我正在学习 Javascript,我正在尝试创建一个简单的下拉菜单。我想要的功能的示例可以在 Google 主页的顶部菜单中看到,其中包含“更多”和“设置”下拉菜单。 我有一个使用 onclick()
我尝试捕捉 tinyMce 编辑器的模糊和焦点事件。 我为此找到了以下方法。 ed.onInit.add(function(ed) { tiny
这里完全被难住了。尝试一些很简单的东西,但它不起作用: $("input.input1, textarea.input1").focus(function(){ $(this).addClas
我有以下 jQuery 函数: 提交表单 $(".content").delegate('.entryButton','click', function() {var form = $(this).c
如何使用 jQuery 在焦点/模糊上切换元素的 CSS? $('.answerSpace').bind('blur', function(){ $('.normProf').toggleClass(
在我的 iPhone 应用程序中,我有一个黑白 UIImage。我需要模糊该图像(高斯模糊即可)。 iPhone 显然知道如何模糊图像,如 it does that when it draws sha
这个问题已经有答案了: Blurring an image via CSS? (6 个回答) 已关闭 7 年前。 我有一个场景。我想随着循环的进行模糊我的图像。我怎样才能做到这一点?这是我的代码。
这个错误是在子字符串方法上抛出的,我发现很多线程都在处理这个问题,但我遇到的问题似乎有所不同。我知道如果您的字符串短于子字符串(开始,结束)大小,它会抛出此错误,但在任何内容传递到方法调用之前都会抛出
是否有简单的解决方案可以在 Qt 中为图像添加运动模糊?还没有找到任何关于模糊的好教程。我需要一些非常简单的东西,我可以理解,如果我可以改变模糊角度,那就太好了。 最佳答案 Qt 没有运动模糊过滤器。
我的搜索框在正常状态下很小。焦点对准时,它会展开,并显示一个提交按钮。这样做是为了节省空间。现在,在模糊时,搜索框再次缩小,提交按钮消失。 问题是,通过使提交按钮成为“竞赛”以在正确的位置单击它,对提
您好,我正在使用 PngBitmapEncoder 从 Canvas 在内存中创建图像。 public void CaptureGraphic() { Canvas canvas = new
我已经搜索过谷歌、这个和其他论坛,但无济于事……太棒了,有没有可能有像 onMiddleClick="blur();"这样的东西?在单击鼠标中键时隐藏链接的焦点边框? 最佳答案 $('a').clic
我无法在我的应用程序中正确渲染我的纹理。我使用的艺术品是精确的,并且已经缩放且尺寸合适,但是当我在手机上渲染它时,我的纹理突然不如原始艺术品清晰/精确,我不明白为什么。 有人遇到过这个问题吗? 最佳答
这里有与上述主题相同的问题但没有得到答复 我这里有布局 我需要在底部布局中使用与顶部布局相同的图像,但使用模糊样式 设置 alpha 没有帮助 - TextView 也会影响 如何虚化down布局的背
我已经搜索了一段时间,但到目前为止没有找到适合我需要的东西。 ( This was helpful, but not convincing ) 从两个不同的来源,我得到两个不同的字符串。我想检查较短的
我有这样的代码: var passwordTextBox = angular.element("#password"); passwordTextBox.blur(function()
设置此 JQuery 函数无法正常工作。有时,如果我单击元素,什么也没有发生,并且它会触发隐藏可折叠菜单的功能,如果单击文档上的任意位置,则不会重定向到正确的 href。有什么更好的方法吗? HTML
尝试通过将坐标列表保存到数组来在多个位置裁剪我的图像后,裁剪区域中的字母变得非常模糊,我无法弄清楚原因。 原图看起来像 裁剪后的图像看起来像 题中代码如下: import numpy as np im
我知道我们可以调暗/模糊屏幕,如 this post 所示. 我应该怎么做才能使它的一部分变暗/模糊,使单个(或多个) View 没有任何效果,从而使整个屏幕具有突出显示 View 的效果? 此外,即
如果有人曾经向 digg 提交过故事,它会检查该故事是否已经提交,我假设是通过模糊搜索。 我想实现类似的东西,想知道他们是否使用开源的 php 类? Soundex 不这样做,句子/字符串的长度可达
我是一名优秀的程序员,十分优秀!