这篇文章将为大家详细讲解有关怎样进行MongoDB文档查询操作,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

成都创新互联公司主要从事成都做网站、网站制作、网页设计、企业做网站、公司建网站等业务。立足成都服务建始,十多年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:18980820575
null
null的查询稍微有点不同,假如我想查询z为null的数据,如下:
db.sang_collect.find({z:null})这样不仅会查出z为null的文档,也会查出所有没有z字段的文档,如果只想查询z为null的字段,那就再多加一个条件,判断一下z这个字段存在不,如下:
db.sang_collect.find({z:{$in:[null],$exists:true}})正则表达式查询
使用正则表达式查询我们在前面也已经介绍过了,这里的正则表达式语法和JavaScript中的正则表达式语法一致,比如查询所有key为x,value以hello开始的文档且不区分大小写:
db.sang_collec.find({x:/^(hello)(.[a-zA-Z0-9])+/i})数组查询
假设我有一个数据集如下:
{
"_id" : ObjectId("59f1ad41e26b36b25bc605ae"),
"books" : [
"三国演义",
"红楼梦",
"水浒传"
]
}查询books中含有三国演义的文档,如下:
db.sang_collect.find({books:"三国演义"})如果要查询既有三国演义又有红楼梦的文档,可以使用$all,如下:
db.sang_collect.find({books:{$all:["三国演义","红楼梦"]}})当然我们也可以使用精确匹配,比如查询books为"三国演义","红楼梦", "水浒传"的数据,如下:
db.sang_collect.find({books:["三国演义","红楼梦", "水浒传"]})不过这种就会一对一的精确匹配。
也可以按照下标匹配,比如我想查询数组中下标为2的项的为"水浒传"的文档,如下:
db.sang_collect.find({"books.2":"水浒传"})也可以按照数组长度来查询,比如我想查询数组长度为3的文档:
db.sang_collect.find({books:{$size:3}})如果想查询数组中的前两条数据,可以使用$slice,如下:
db.sang_collect.find({},{books:{$slice:2}})注意这里要写在find的第二个参数的位置。2表示数组中前两个元素,-2表示从后往前数两个元素。也可以截取数组中间的元素,比如查询数组的第二个到第四个元素:
db.sang_collect.find({},{books:{$slice:[1,3]}})数组中的与的问题也值得说一下,假设我有如下数据:
{
"_id" : ObjectId("59f208bc7b00f982986c669c"),
"x" : [
5.0,
25.0
]
}我想将数组中value取值在(10,20)之间的文档获取到,如下操作:
db.sang_collect.find({x:{$lt:20,$gt:10}})此时上面这个文档虽然不满足条件却依然被查找出来了,因为5<20,而25>10,要解决这个问题,我们可以使用$elemMatch,如下:
db.sang_collect.find({x:{$elemMatch:{$lt:20,$gt:10}}})$elemMatch要求MongoDB同时使用查询条件中的两个语句与一个数组元素进行比较。
嵌套文档查询
嵌套文档有两种查询方式,比如我的数据如下:
{
"_id" : ObjectId("59f20c9b7b00f982986c669f"),
"x" : 1.0,
"y" : {
"z" : 2.0,
"k" : 3.0
}
}想要查询上面这个文档,我的查询语句如下:
db.sang_collect.find({y:{z:2,k:3}})但是这种写法要求严格匹配,顺序都不能变,假如写成了db.sang_collect.find({y:{k:3,z:2}}),就匹配不到了,因此这种方法不够灵活,我们一般推荐的是下面这种写法:
db.sang_collect.find({"y.z":2,"y.k":3})这种写法可以任意颠倒顺序。
关于怎样进行MongoDB文档查询操作就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
分享文章:怎样进行MongoDB文档查询操作
文章链接:http://www.jxjierui.cn/article/gspdcc.html


咨询
建站咨询
