返回顶部
首页 > 资讯 > 数据库 >怎么在MongoDB中对数组中的元素进行查询
  • 120
分享到

怎么在MongoDB中对数组中的元素进行查询

2024-04-02 19:04:59 120人浏览 八月长安
摘要

怎么在mongoDB中对数组中的元素进行查询?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。前言MonGoDB是文档型数据库,每个文档(doc)

怎么在mongoDB中对数组中的元素进行查询?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

前言

MonGoDB是文档型数据库,每个文档(doc)表示数据的一项记录。相比关系型DB的row只能使用简单的数据类型,doc能够使用复杂的数据类型:内嵌doc,数组。MongoDB的数组是一系列元素的集合,使用中括号 [] 表示数组,例如:[1,2,3]的元素是整数值,[{name:"t5"}, {name:"t7"}],[ {name:"t5", age:21}, {name:"t7", age:22} ]的元素是doc。

在MongoDB中,数组元素允许重复,元素的位置是固定的。如果两个数组相等,那么这两个数组的元素和及其位置都相同。

MongoDB中根据数组子元素进行匹配,有两种方式。

  • 使用 “[数组名].[子元素字段名]” 的方式进行匹配。

  • 使用 “[数组名]” $elemMatch { [子元素字段名] }的方式。

不同点在于所匹配的主体不同。

“[数组名].[子元素字段名]” 的方式匹配的主体为 “[数组名]”, 适用于单个条件,如果是多个条件, 则变成数组子元素之间的“或”运算。

请看示例:

假设某个集合内有2条数据:

document1 如下:

{ 
 "_id" : "123", 
 "name" : "人文医学", 
 "qList" : [
  {
   "qid" : 1, 
   "content" : "医学伦理学的公正原则", 
   "reorderFlag" : 1
  }, 
  {
   "qid" : 2, 
   "content" : "制定有关人体实验的基本原则", 
   "reorderFlag" : 0
  }
 ]
}

document2 如下:

{ 
 "_id" : "124", 
 "name" : "人文医学2", 
 "qList" : [
  {
   "qid" : 1, 
   "content" : "医学伦理学的公正原则", 
   "reorderFlag" : 0
  }, 
  {
   "qid" : 2, 
   "content" : "制定有关人体实验的基本原则", 
   "reorderFlag" : 1
  }
 ]
}

找出数组中, 具有 qid=1并且reorderFlag=0的记录

查询数组内同一条记录同时满足2个条件的语句:

{ "qList": { $elemMatch: { "qid": 1, "reorderFlag": 0} } }

查询结果是:

{ 
 "_id" : "124", 
 "name" : "人文医学2", 
 "qList" : [
  {
   "qid" : NumberInt(1), 
   "content" : "医学伦理学的公正原则", 
   "reorderFlag" : NumberInt(0)
  }, 
  {
   "qid" : NumberInt(2), 
   "content" : "制定有关人体实验的基本原则", 
   "reorderFlag" : NumberInt(1)
  }
 ]
}

可以看到, 其执行结果是, 对数组内的每一个子元素, 执行 $elemMatch 匹配, 可以进行多个条件的匹配。

找出数组中, qid=1 或者 reorderFlag=0的记录

数组整体能满足以下2个条件:

{ "qList.qid": 1, "qList.reorderFlag": 0}

执行的主体是 qList, 要求: 有某些子元素满足 qid=1, 也要有某些子元素满足 reorderFlag=0`。

查询结果是:

{ 
 "_id" : "123", 
 "name" : "人文医学", 
 "qList" : [
  {
   "qid" : NumberInt(1), 
   "content" : "医学伦理学的公正原则", 
   "reorderFlag" : NumberInt(1)
  }, 
  {
   "qid" : NumberInt(2), 
   "content" : "制定有关人体实验的基本原则", 
   "reorderFlag" : NumberInt(0)
  }
 ]
}
{ 
 "_id" : "124", 
 "name" : "人文医学2", 
 "qList" : [
  {
   "qid" : NumberInt(1), 
   "content" : "医学伦理学的公正原则", 
   "reorderFlag" : NumberInt(0)
  }, 
  {
   "qid" : NumberInt(2), 
   "content" : "制定有关人体实验的基本原则", 
   "reorderFlag" : NumberInt(1)
  }
 ]
}

可以看到, 其执行结果是, 对数组进行匹配, 其中需要有子元素 满足 "qList.qid": 1, 还需要有子元素 满足 "qList.qid": 1, , 适合进行单个条件的匹配。

如果是单个条件匹配, 则以下方式结果是一样的。

{ "qList.qid": 1}

或者

{ "qList": { $elemMatch: { "qid": 1} } }

查询的结果都是2条记录。

看完上述内容,你们掌握怎么在MongoDB中对数组中的元素进行查询的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网数据库频道,感谢各位的阅读!

您可能感兴趣的文档:

--结束END--

本文标题: 怎么在MongoDB中对数组中的元素进行查询

本文链接: https://lsjlt.com/news/54610.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么在MongoDB中对数组中的元素进行查询
    怎么在MongoDB中对数组中的元素进行查询?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。前言MongoDB是文档型数据库,每个文档(doc)...
    99+
    2024-04-02
  • PHP中怎么对数组进行模糊查询
    这篇文章主要介绍“PHP中怎么对数组进行模糊查询”,在日常操作中,相信很多人在PHP中怎么对数组进行模糊查询问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP中怎么对数组进行模糊查询”的疑惑有所帮助!接下来...
    99+
    2023-07-06
  • MongoDB如何查询数组里面的元素
    在MongoDB中,可以使用以下方式查询数组中的元素:1. 精确匹配:使用$elemMatch运算符来匹配数组中包含指定元素的文档。...
    99+
    2023-08-23
    MongoDB
  • jquery怎么查询数组元素
    本篇内容介绍了“jquery怎么查询数组元素”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • gorm postgres 查询 json 数组中的元素
    gorm postgres 查询 json 数组中的元素是一个常见的需求,特别是在处理复杂的数据结构时。在使用 GORM 进行数据库查询时,我们可以通过一些技巧来实现这个目标。在本文中...
    99+
    2024-02-10
  • 怎么在python中对元组进行排序
    本篇文章为大家展示了怎么在python中对元组进行排序,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。python的数据类型有哪些python的数据类型:1. 数字类型,包括int(整型)、long(...
    99+
    2023-06-14
  • php怎么查询数组元素的key
    本文操作环境:Windows10系统、PHP7.1版、Dell G3电脑。php怎么查询数组元素的keykey() 函数返回数组内部指针当前指向元素的键名。若发生错误,则函数返回 FALSE。 key() 函数用来获得数组中当前元素的键名。...
    99+
    2021-04-24
    php
  • 怎么在MySQL中对查询进行优化
    本篇文章给大家分享的是有关怎么在MySQL中对查询进行优化,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、创建索引规范在学习索引优化之前,需要对创建索引的规范有一定的了解,此...
    99+
    2023-06-08
  • Go中怎么使用MongoDB进行数据查询
    这篇文章主要讲解了“Go中怎么使用MongoDB进行数据查询”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Go中怎么使用MongoDB进行数据查询”吧!首先,我们需要安装“mgo” Go-M...
    99+
    2023-07-05
  • 利用Java怎么对数组中的元素进行填充与替换
    今天就跟大家聊聊有关利用Java怎么对数组中的元素进行填充与替换,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。      ...
    99+
    2023-05-31
    java ava
  • 使用java怎么在数组中查找元素
    这篇文章将为大家详细讲解有关使用java怎么在数组中查找元素,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序、Web应用程序、...
    99+
    2023-06-14
  • vb怎么在数组中查找指定元素
    在VB中,可以使用Array类的IndexOf方法来查找数组中的指定元素。具体用法如下: Dim arr As Integer() ...
    99+
    2024-02-29
    vb
  • MongoDB中怎么查询数组下标
    这篇文章将为大家详细讲解有关MongoDB中怎么查询数组下标,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。  Mongodb的集合b中,保存了姓名...
    99+
    2024-04-02
  • 使用indexOf等在JavaScript的数组中进行元素查找和替换
    复制代码 代码如下: <html> <head> <title> Extend JavaScript Array Method </titl...
    99+
    2022-11-15
    indexOf 数组元素 查找替换
  • php数组怎么查询元素位置
    本教程操作环境:windows7系统、PHP7.1版、DELL G3电脑php数组查询元素位置的方法:方法1:利用array_search()函数<php $array=array(2,3,4,1,5); $find=3; //利用...
    99+
    2015-10-15
    php 数组
  • 记一次Mongodb数据库查询之包含所有指定元素的数组或者都在指定元素的数组中 - du
      这里记录一个查询需求:数据库中字段的值(数组类型)都在指定的数组中。举例说一下实际场景,数据库中一个字段存储用户“可以使用的编程语言”,一般都会是多个,所以该字段是数组格式。现在要查询的是:会c#、javascript或者只会c#或者...
    99+
    2017-06-27
    记一次Mongodb数据库查询之包含所有指定元素的数组或者都在指定元素的数组中 - du
  • 使用PHP的array_reduce()函数对数组中的元素进行累加
    使用PHP的array_reduce()函数对数组中的元素进行累加在PHP中,array_reduce()函数是一个非常强大的函数,它允许我们对数组中的元素进行累加操作。array_reduce()函数接收一个数组和一个回调函数作为参数,并...
    99+
    2023-11-03
    PHP array_reduce() 累加
  • 怎么在postgresql中对jsonb数据进行查询和修改
    今天就跟大家聊聊有关怎么在postgresql中对jsonb数据进行查询和修改,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。JS是什么JS是JavaScript的简称,它是一种直译式...
    99+
    2023-06-06
  • 怎么用filter方法对数组元素进行过滤
    本篇内容介绍了“怎么用filter方法对数组元素进行过滤”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • 怎么在java项目中利用mongodb进行查询操作
    本篇文章为大家展示了怎么在java项目中利用mongodb进行查询操作,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。java 中mongodb的各种操作查询的实例详解一. 常用查询: 查询一条数据:...
    99+
    2023-05-31
    java mongodb
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作