位置: 编程技术 - 正文

MongoDB如何对数组中的元素进行查询详解(mongodb aggregate count)

编辑:rootadmin

推荐整理分享MongoDB如何对数组中的元素进行查询详解(mongodb aggregate count),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mongodb 一对多,mongodb aggregate count,mongodb aggregate count,mongodb key value,mongodb 一对多,mongodb aggregate count,mongodb 一对多,mongodb 对象,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

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

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

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

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

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

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

请看示例:

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

document1 如下:

document2 如下:

MongoDB如何对数组中的元素进行查询详解(mongodb aggregate count)

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

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

查询结果是:

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

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

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

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

查询结果是:

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

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

或者

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

总结

标签: mongodb aggregate count

本文链接地址:https://www.jiuchutong.com/biancheng/312082.html 转载请保留说明!

上一篇:Mysql触发器在PHP项目中用来做信息备份、恢复和清空(mysql触发器在哪里建)

下一篇:Mac中mongoDB的安装与卸载步骤详解(mongodb安装教程图解)

  • 发票超过认证期有什么影响
  • 应交税费待抵扣进项税额
  • 广播影视服务税率2023
  • 流转税包括哪些税种2022
  • 报关金额必须跟收汇金额一致吗?
  • 金税四期对企业的风险
  • 财务报表年报怎么更正
  • 支付残疾人保证金的账务处理
  • 出口货物预收账款会计分录
  • 净资产合计低于实际收益
  • 基本存款账户能向银行借款吗
  • 遗失发票如何处理
  • 个人开增值税普票有没有限额
  • 新公司营业执照经营范围越多越好吗
  • 个人对公益事业的认识与看法
  • 增加实收资本印花税税目
  • 软件企业研发费用占比要求
  • 销售单怎么设置打几行
  • 企业所得税固定资产折旧计算
  • 房屋契税怎样计算公式
  • 竣工决算调整入库流程
  • 打开游戏时总是出现需要新应用打开此MS
  • 企业间借款增值税怎么算
  • 主合同变更对保险的影响
  • 美团提现手续费入哪个会计科目
  • 消防工程改造方案
  • 贷款滞纳金如何收取
  • php 用户注册
  • 增值税免征与即征的区别
  • 培训公司要交哪些税
  • 民营医院所得税税率
  • gfortran编译命令
  • 羊羊 过好
  • 自费出版违法吗
  • 销售不同商品的会计分录
  • 一般纳税人普票可以抵扣吗
  • 经济独立可以做什么
  • 服务费减免税款怎么算
  • 无形资产资产处置损益和营业外收入
  • 百旺税控盘跨月发票作废
  • 电子承兑汇票贴现怎么做账
  • 水电费专用发票模板
  • 免税收入和不征税收入有何区别
  • 未分配利润分配后在报表如何体现
  • 固定资产卡片账是什么
  • 公司法人的车辆给公司用可以报销费用吗
  • 物业电费加价如何处理
  • 应付账款入账金额可以包括哪些内容?
  • 收到科技局补贴金费怎么入账
  • 专项应付款在借方
  • 取得与收益相关的政府补助计入什么科目
  • 出口退税进项税都抵扣了怎么办
  • 超市发票报销一般写什么明细
  • 小规模什么情况下必须转为一般纳税人
  • 小规模纳税人的认定标准是什么
  • 单位员工购买本地保险
  • 营业外收入算未开票收入吗
  • 增值税税控系统专用设备费及技术维护费抵扣
  • Mac OS X 10.9 Mavericks系统怎么激活?
  • 苹果macbook怎么切换系统
  • macOS 10.12 Beta 7更新了什么 macOS 10.12 Beta7更新内容汇总
  • 不能用鼠标
  • vmware centos8
  • inc是什么软件
  • win7怎么修改开始菜单样式
  • win7适用ie几
  • 让人吃惊的成语有哪些
  • cocos2d官网
  • echarts splitnumber
  • nodejs可以直接操作数据库
  • 64位Win7环境下vs2013配置opengl
  • java获取两个日期间的所有月份
  • 基于vue的app
  • javascript学习指南
  • android点击事件传递机制
  • python中运算符/和//的区别
  • jquery.form.min.js
  • 北京国税电子税务局
  • 2023年内蒙古房贷利率
  • 增值税进项税额抵扣凭证
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设