位置: 编程技术 - 正文

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

  • 小微企业所得税费用怎么算
  • 稿酬所得个人所得税税率表
  • 汇算清缴补缴企业所得税怎么做账
  • 研发费用加计扣除是什么意思啊
  • 建筑业资源税如何缴纳
  • 汽车维修费可以计入交通费吗
  • 发票未到已验收什么意思
  • 普通发票不能抵扣进项税额怎么做账
  • 固定资产折旧购买日期还是使用日期呢
  • 预算为负数实际为负数 怎么计算完成率
  • 从业人数和资产总额是灰色
  • 存在商业折扣的情况下,应收账款按什么金额入账?
  • 同一投资主体内部所属企业之间土地,房屋权属的划转
  • 销售人员出差补助计入什么科目
  • 股权转让资本公积怎么处理
  • 电子发票对航天信息利空吗
  • 国税定额发票有效期是多长时间
  • 小规模纳税人进货需要发票吗
  • 资产处置损益是收入还是费用
  • 付工程款现金怎么做凭证?
  • 存货跌价准备在报表什么项目列示
  • 小规模的应交税费涉及几个三级明细
  • 网上申领发票怎么清卡
  • 对公账户发工资的利弊
  • 代驾费用入什么二级科目
  • 资本公积转增资本什么意思
  • 企业对外股权投资涉及税收
  • 企业为开发新产品新技术新工艺
  • windows 11预览版
  • 代扣代缴个人所得税账务处理
  • 工业会计做账的基本流程
  • 其他存货包括哪些内容
  • 潜亏挂账是什么意思
  • 实际收到的货款怎么做账
  • 金融企业风险资产处理相关税收政策
  • 终止劳动合同赔偿需要缴税吗
  • 出口零退税率商品目录
  • thinkphp i方法
  • php 封装
  • 金银首饰以旧换新增值税处理
  • ChatGPT会让6个低端岗位失业
  • 发票作废发票怎么处理
  • jquery设置不可用
  • 关于低值易耗品的说法中不正确的是
  • 退还多缴纳税款
  • 企业在什么情况下可以不交税
  • 缴纳上年汇算清缴的分录
  • 使用增值税发票违法吗
  • 长期待摊费用账务处理包括哪两部分
  • 金蝶软件发票录入什么科目
  • 增值税专用发票怎么开
  • 应收账款余额百分比法与账龄分析法有何异同
  • 一次性计入当期成本费用是什么意思
  • 报税合同
  • 少数股东损益会出现负数吗
  • 普票部分红冲发票需要收回原发票吗
  • 印花税每个月都计提吗
  • 非同一控制下企业合并,企业合并成本包括
  • 无票收入怎么写分录
  • 会计循环属于什么流程
  • mysql函数返回值类型
  • 快速调用cmd
  • win10 server2008
  • sguard是什么文件夹
  • win10连接ubuntu20.04远程桌面
  • win7电脑能登qq但打不开网页怎么办
  • Win7笔记本突然wifi功能没了
  • windows8任务栏在下面怎么不显示
  • linux系统中文输入法切换不出来
  • windows7怎么关不了机怎么办
  • 浅谈一下新冠的好处
  • androidstudio更改工程名字
  • OpenGL ES Emulator比较
  • 启动游戏使用的文件夹什么意思
  • 如何用python开发软件
  • android手机屏幕采集触摸区域所有点
  • 山东无犯罪记录证明网上申请
  • 朝阳税务总局
  • 盐城城南新区的邮政编码是多少号
  • 选矿比怎么算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设