文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎样进行MongoDB文档查询操作

2023-06-19 12:44

关注

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

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文档查询操作就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯