之前我们介绍过使用文本选择器($text)查询文档,如果您需要进一步了解,可以参考:
本篇,我们介绍使用$regex选择器查询文档:
一、准备工作
初始化学生信息数据
db.studentInfos.insertMany([
{ "_id": 1, "name": "张三1", "sports": "羽毛球、乒乓球", fruits: "apple, banana", introduce: "大家好,我喜欢运动,但是我不喜欢铅球,因为它太重了" },
{ "_id": 2, "name": "李四1", "sports": "篮球、乒乓球、跑步", fruits: "Apple", introduce: "大家好,我喜欢水果,但是不喜欢吃橘子,因为它太酸了" },
{ "_id": 3, "name": "王五1", "sports": "足球、羽毛球", fruits: "Banana", introduce: "大家好,我喜欢水果,喜欢运动" },
{ "_id": 4, "name": "张三2", "sports": "网球、铅球", fruits: "orange", introduce: "大家好,我喜欢水果与健身" },
{ "_id": 5, "name": "李四2", "sports": "乒乓球", fruits: "Orange, Apple", introduce: "大家好,我喜欢乒乓球运动" },
{ "_id": 6, "name": "王五2", "sports": "篮球", fruits: "Orange, Banana", introduce: "hello,i like sports" },
{ "_id": 7, "name": "张三3", "sports": "跑步、跳绳", fruits: "Orange, apple, Banana", introduce: "haha, 与健身相比,我更喜欢吃" },
{ "_id": 8, "name": "李四3", "sports": "足球", fruits: "orange, banana", introduce: "足球和橘子是我的最爱" },
{ "_id": 9, "name": "王五3", "sports": "跆拳道", fruits: "Banana", introduce: "我不喜欢健身,我喜欢突破自己" }
])
二、正则选择器($regex)
语法:
{ <field>: { $regex: /pattern/, $options: '<options>' } }
{ <field>: { $regex: 'pattern', $options: '<options>' } }
{ <field>: { $regex: /pattern/<options> } }
{ <field>: /pattern/<options> }
上面的三种语法都是用于正则表达式进行检索的。
/pattern/:代表的式正则表达式对象
'pattern':代表的式正则表达式文本
$options:代表的是选项,
i:不区分大小写
m:正则表达式中包含了锚点(^代表开始,$代表结尾)
三、例子:检索furits中包含apple的文档
查询文档的命令如下:
db.studentInfos.find({
fruits: { $regex: /apple/, $options: '' }
})
等效于:
db.studentInfos.find({
fruits: { $regex: /apple/ }
})
等效于:
db.studentInfos.find({
fruits: /apple/
})
查询文档的结果如下:
{ "_id" : 1, "name" : "张三1", "sports" : "羽毛球、乒乓球", "fruits" : "apple, banana", "introduce" : "大家好,我喜欢运动,但是我不喜欢铅球,因为它太重了" }
{ "_id" : 7, "name" : "张三3", "sports" : "跑步、跳绳", "fruits" : "Orange, apple, Banana", "introduce" : "haha, 与健身相比,我更喜欢吃" }
四、例子:检索furits中包含apple的文档(不区分大小写)
在上面的例子中,我们发现fruits中带有Apple的文档未被检索出来,原因是默认情况下检索的文本是区分大小写的,如果不区分大小写,可使用下面的查询命令:
db.studentInfos.find({
fruits: { $regex: /apple/, $options: 'i' }
})
等效于:
db.studentInfos.find({
fruits: { $regex: /apple/i }
})
等效于:
db.studentInfos.find({
fruits: /apple/i
})
查询文档的结果如下:
{ "_id" : 1, "name" : "张三1", "sports" : "羽毛球、乒乓球", "fruits" : "apple, banana", "introduce" : "大家好,我喜欢运动,但是我不喜欢铅球,因为它太重了" }
{ "_id" : 2, "name" : "李四1", "sports" : "篮球、乒乓球、跑步", "fruits" : "Apple", "introduce" : "大家好,我喜欢水果,但是不喜欢吃橘子,因为它太酸了" }
{ "_id" : 5, "name" : "李四2", "sports" : "乒乓球", "fruits" : "Orange, Apple", "introduce" : "大家好,我喜欢乒乓球运动" }
{ "_id" : 7, "name" : "张三3", "sports" : "跑步、跳绳", "fruits" : "Orange, apple, Banana", "introduce" : "haha, 与健身相比,我更喜欢吃" }
五、例子:检索furits中第一个是apple的文档(不区分大小写)
查询文档的命令如下:
db.studentInfos.find({
fruits: { $regex: /^apple/, $options: 'im' }
})
等效于:
db.studentInfos.find({
fruits: { $regex: /^apple/im }
})
等效于:
db.studentInfos.find({
fruits: /^apple/im
})
查询文档的结果如下:
{ "_id" : 1, "name" : "张三1", "sports" : "羽毛球、乒乓球", "fruits" : "apple, banana", "introduce" : "大家好,我喜欢运动,但是我不喜欢铅球,因为它太重了" }
{ "_id" : 2, "name" : "李四1", "sports" : "篮球、乒乓球、跑步", "fruits" : "Apple", "introduce" : "大家好,我喜欢水果,但是不喜欢吃橘子,因为它太酸了" }
六、例子:检索furits中最后一个是apple的文档(不区分大小写)
查询文档的命令如下:
db.studentInfos.find({
fruits: { $regex: /apple$/, $options: 'im' }
})
等效于:
db.studentInfos.find({
fruits: { $regex: /apple$/im }
})
等效于:
db.studentInfos.find({
fruits: /apple$/im
})
查询文档的结果如下:
{ "_id" : 2, "name" : "李四1", "sports" : "篮球、乒乓球、跑步", "fruits" : "Apple", "introduce" : "大家好,我喜欢水果,但是不喜欢吃橘子,因为它太酸了" }
{ "_id" : 5, "name" : "李四2", "sports" : "乒乓球", "fruits" : "Orange, Apple", "introduce" : "大家好,我喜欢乒乓球运动" }