位置: 编程技术 - 正文

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

  • 收到个税手续费退费会计分录
  • 关税的计算公式是什么
  • 企业利息收入需要交哪些税
  • 软件企业认定流程
  • 企业实缴不到位怎么办
  • 月销售额不超过10万
  • 调整应付账款折扣到营业外收入吗
  • 销售收入的暂估入账是否结转利润
  • 应收账款平均占用资金的变动额
  • 增值税专票经办人怎么填
  • 增值税发票丢了怎么补开
  • 记账凭证的填写示例
  • 长期股权投资权益法下初始投资成本
  • 企业所得税弥补亏损怎么算
  • 领用外购材料用于动产
  • 小微企业所得税优惠政策2023
  • 包销和代销哪个风险大
  • 上月未计提税费,本月可以补计提吗
  • 营业外收入可以在贷方吗
  • win11任务管理器在哪里打开
  • 公司多缴税款了怎么办?可以退吗?
  • 外贸企业代理出口销售的出口退税手续
  • 绿萝怎么修剪才能更旺盛
  • 其他综合收益需要结转吗
  • 回迁安置房是否有产权
  • php设计模式六大原则
  • 定额发票已验旧是什么意思
  • php代码生成
  • vue3ts
  • 【第三趴】uni-app页面搭建与路由配置(了解工程目录结构、学会搭建页面、配置路由并成功运行)
  • 谷歌浏览器调试窗口怎么放下面
  • 帝国cms app
  • 银行代发工资会扣个人所得税吗
  • 安装充电桩电费怎么收
  • 采购货未到收到发票
  • 其他应收账款怎么做预算会计分录
  • 超过五年的未弥补亏损如何处理?
  • wordpress站点地址如何设置
  • 织梦如何使用
  • python如何使用requests检查请求
  • 小规模纳税人的税率是多少
  • 个人所得税利息股息红利所得适用比例税率
  • 收到红字发票账务处理应附哪些资料呢
  • 认缴资金可以增加吗
  • 微信提现手续费多少?
  • 投资收益科目在利润表中怎么填
  • 新公司季初资产总额填什么
  • 农产品没有发票怎么办
  • 小规模纳税人买车可以抵扣哪些税
  • 固定资产是指什么
  • 印花税征税范围2021
  • 填收入与成本明细怎么填
  • solaris教程
  • ubuntu16.04创建用户
  • wsinspector.exe是什么进程
  • version 2什么意思
  • ubuntu operation not permitted
  • mac uuid查询
  • 苹果电脑快捷键截图怎么截
  • avgorange是什么文件
  • mac怎么共享打印机设备
  • Skype.exe - Skype是什么进程 有什么用
  • win8.1 操作中心
  • 怎么快速
  • jquery示例
  • js响应式布局
  • Cocos2dx ParticleEditor粒子编辑器
  • javascript 函数定义
  • u盘备份系统操作步骤
  • shell 管道 并行
  • jqueryui dialog
  • unity资源库
  • js代码怎么使用
  • 1、Android Studio创建android项目
  • jquery滚动插件
  • 税务软件服务商
  • 重庆国税电子税务登录
  • 农村报账员的基本职责
  • 乌鲁木齐市公立幼儿园有哪些
  • 青岛个人所得税咨询电话是多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设