位置: 编程技术 - 正文

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

  • 配建保障房税收规定
  • 跨月的增值税专用发票怎么作废重开
  • 小规模纳税人可以收专票吗
  • 月末只有进项税需要把转出未交增值税转到未交增值税
  • 增值税现代服务业6大行业
  • 企业所得税计入什么费用
  • 个人所得税减除费用6万元什么意思
  • 月中入职新公司社保谁交
  • 等额本息还款的特点
  • 房地产土地使用税已售面积如何减
  • 向香港公司支付服务费税率
  • 印花税少提了怎么办
  • 网上纳税申报怎么填
  • 行政相对人和行政管理相对人的区别
  • 出售固定资产要交哪些税
  • 企业在什么情况下做薪酬诊断
  • 自行建造厂房一座,现已完工,经验收后交付费用
  • 年终奖金个人所得税计算公式
  • 开具发票的收入如何做账务处理?
  • 原材料座椅报废怎么处理
  • 收到退回所得税怎么做帐
  • 应交增值税有哪些
  • 工信部推出一键解绑怎么用
  • 属于项目的一个实例
  • 飞机票本身包含保险吗多少钱
  • 民营非盈利企业好申请吗
  • 生产部门设备折旧费
  • eml文件怎么打开方式
  • 一般纳税人资质证明文件去哪打印
  • php中的header函数
  • php核心编程
  • 电脑dwm.exe是什么
  • 电商平台第三方服务
  • 房屋装修费如何入账
  • 借款凭证会计分录是什么
  • 怎么确认个税填报成功
  • vscode插件vuter
  • 投资性房地产成本法转公允价值法
  • vue自定义页面
  • html多页面
  • vue前端常见面试题
  • 重复上次命令
  • 视同销售的增值税怎么申报
  • 进项税加计抵减是什么意思
  • 企业所得税季度申报表怎么填
  • 独资设立的有限公司
  • 织梦系统网站搭建教程
  • mongodb安装过程
  • 电子税务局没有税务数字账户怎么办
  • db2数据库安装服务器的环境
  • 一般纳税人交增值税的账务处理
  • 企业的研发活动阶段包括
  • sql server数据库数据备份
  • sqlserver性能优化方案
  • MySQL利用不同的流程语句输出1到200的和
  • 批量更新数据库最多多少条
  • win7经典版怎么换回win10
  • xp恢复回收站删除文件
  • window2008 64位系统没有office组件问题分析及解决
  • debian10配置ipv6地址
  • 高危禁止安装怎么解除
  • win双系统怎么切换
  • win7系统如何调节电脑屏幕亮度
  • 在Linux系统中如何打开R语言控制台
  • linux 去除换行
  • win7系统怎么设置电源
  • 学习英语
  • js数据的基本类型有哪些
  • unity jsonutility
  • 查找第一个字符
  • jQuery.ajax实现根据不同的Content-Type做出不同的响应
  • jquery 列表实现
  • js 编程
  • ajax 分页
  • 河北税务局是干嘛的
  • 群租房怎么举报电话
  • 为什么虚开增值税属于犯罪行为
  • 携程怎么订
  • 河南税务申报
  • 越南入关要给小费吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设