位置: 编程技术 - 正文

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安装教程图解)

  • 车险发票不含车船税怎么记账
  • 企业转出多交增值税吗
  • 残疾人个人所得税
  • 企业所得税季度预缴怎么计算
  • 技术维护费计入哪里
  • 不动产什么时候可以抵扣进项税额
  • 收银设备如何入账的
  • 软件委托开发合同印花税
  • 商贸公司收到的邮票怎么做账
  • 地下建筑房产税减免优惠政策
  • 受托加工费直接计入生产成本
  • 职工基本医疗保险单位交的钱去哪里了
  • 房屋租赁违法
  • 水利建设基金怎么计提
  • 注册资本未到位注销公司处理
  • 行政事业单位2014年前已交社保费
  • 普通发票企业有用吗
  • 福利费开专票怎么处理
  • 建筑公司一般纳税人增值税税率
  • 食用盐的增值税是多少
  • 开发票时的数据可以四舍五入吗
  • 职工福利费扣除率是多少
  • 固定资产折旧计算方法
  • 工资只发一半
  • system 命令
  • 进口关税和增值税
  • 怎么看腾讯游戏
  • php变量设置
  • u深度u盘启动盘制作工具官网
  • 怎么关闭windows defender
  • 经销商计提折扣怎么做账
  • windows 10预览版
  • 招待费审批流程
  • 烟草企业亏损
  • 梅林澳大利亚信号好最好吗
  • php5 mysql教程
  • 无效借款合同自被确认为无效之日起无效
  • 支付航天信息服务费怎么入账
  • 无法按时交纳税怎么办
  • ip命令查看ip地址
  • ftp port命令
  • 进口设备退税如何计算
  • 存续分立会计处理原则
  • 公户直接转给私人账户违法么
  • 删除mysql57服务
  • 电算化会计档案论文答辩自述稿
  • mysql常用语
  • 加班餐费和误餐费的区别
  • 以前年度损益调整结转到哪里
  • 高新技术企业补助需要交所得税吗
  • 财务报告编制原则
  • 收到银行承兑汇票后,如何取钱
  • 微信转账截图可以作为会计凭证吗
  • 工程领用原材料账务处理
  • 成本暂估跨年度怎么算
  • 跨年收入会计分录
  • 固定资产折旧完了还算固定资产吗
  • 收银员长款短款什么意思
  • 国税定额发票有什么用
  • 工业会计建账做账流程
  • mysql基于什么模型
  • 纸嫁衣6第四章攻略全文图解
  • solaris安装教程
  • win7系统桌面设置
  • sealmon.exe - sealmon是什么进程 有什么用
  • win7系统关闭自动休眠
  • linux常用网络工具
  • linux的newgrp
  • perl的正则表达式语法
  • jQuery的extend方法【三种】
  • 编写注册表文件
  • python动态参数应用
  • jquery自定义组件
  • js中调用java
  • javascript学习指南
  • js拖动效果
  • kmp算法理解
  • 广西职称申报系统入口220
  • 如何在国税网上做企业会计制度备
  • 江苏省2023年1号文
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设