MongoDB 正则表达式
正则表达式是使用单个字符串来描述、匹配一系列符合某个句法规则的字符串。
MongoDB 使用 $regex 操作符来设置匹配字符串的正则表达式。
MongoDB使用PCRE (Perl Compatible Regular Expression) 作为正则表达式语言。
不同于全文检索,我们使用正则表达式不需要做任何配置。
实例
已知test 集合数据:
/* 1 */
{
"_id" : ObjectId("63e36e36da0f660d6928a751"),
"id" : 200.0,
"name" : "zhAng",
"age" : 32.0
}
/* 2 */
{
"_id" : ObjectId("63e36e36da0f660d6928a752"),
"id" : 22.0,
"name" : "wang",
"age" : 18.0
}
/* 3 */
{
"_id" : ObjectId("63e36ea0da0f660d6928a753"),
"id" : 300.0,
"name" : "zeng",
"age" : 28.0,
"tag" : [
"red",
"green"
]
}
/* 4 */
{
"_id" : ObjectId("63e37016da0f660d6928a754"),
"id" : 888.0,
"name" : "zeng",
"age" : 20.0,
"tag" : [
"red",
"blue"
]
}
使用正则表达式
以下命令使用正则表达式查找name中包含 an字符串数据:
db.test.find({name:{$regex:"an"}})
查询结果:

以上查询也可以写为:
db.test.find({name:/an/})
查询结果:

不区分大小写的正则表达式
如果检索需要不区分大小写,我们可以设置 $options 为 $i。
以下命令将查找不区分大小写的字符串 an:
db.test.find({name:{$regex:"an",$options:"$i"}})
查询结果:

数组元素使用正则表达式
我们还可以在数组字段中使用正则表达式来查找内容。 这在标签的实现上非常有用,如果需要查找包含以 re开头的标签数据(re或 red), 可以使用以下代码:
db.test.find({tag:{$regex:"re"}})
查询结果:

优化正则表达式查询
- 如果你的文档中字段设置了索引,那么使用索引相比于正则表达式匹配查找所有的数据查询速度更快。
- 如果正则表达式是前缀表达式,所有匹配的数据将以指定的前缀字符串为开始。例如: 如果正则表达式为 ^tut ,查询语句将查找以 tut 为开头的字符串。



















