位置: 编程技术 - 正文

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

  • 应交企业所得税会计分录
  • 合同不交印花税合法吗
  • 销售费用计入产品生产成本吗
  • 个体户开票超30次后如何开票
  • 资产减值损失为什么不能转回
  • 各种收入与应纳税额的比例
  • 罚款收入需要开票吗
  • 结构性存款质押 叫停
  • 母子公司之间的管理费可以税前扣除吗
  • 购销企业
  • 5.0车船税和交强险一年多少钱
  • 空调安装企业能申请工程发票吗?
  • 小规模纳税人咨询服务费税率是多少
  • 销售返利如何做分录
  • 股权激励会计处理分录和企业所得税
  • 补缴去年的社保怎么做账
  • 出口退税企业的税负率怎么算?
  • 企业研发过程中特殊收入的会计处理
  • 股权投资涉税问题
  • 酒店安装监控费用谁出
  • 什么货物出口最多
  • 销售折让和折扣的风险点
  • 毛利率计算公式举例说明
  • 小规模企业有收入吗
  • linux中安装命令
  • 总公司拨给分公司的钱怎么平账
  • ieview.exe 是什么
  • 考核工资可以不发吗
  • 如何理解土地使用制度
  • 公司缴纳残保金怎么做账
  • 烟花绽放的除夕夜题目
  • 蓝桥杯咋样
  • 原始凭证一般没有
  • 下脚料收入计入什么科目
  • GCC strict aliasing – 嫉妒就是承认自己不如别人
  • 待抵扣进项税额是什么情况下用的
  • 企业为其他企业担保有什么责任
  • 代扣代缴境外增值税时间
  • 进项税转出金额是发票上的哪个
  • mysql的union语句
  • 合并报表少数股东权益是什么
  • 三方合同如何解除
  • 关于sqlserver数据库服务器登录账户的说法错误的是
  • 理财产品怎么收费
  • 一般纳税人企业所得税5%还是25%
  • 销售返利可以税前扣除吗
  • 月末进项税大于销项税额怎么结转
  • 负数发票怎样做账
  • 残保金账务处理会计科目
  • 收到增值税发票月饼
  • 个体工商户怎么注册
  • 发出商品 会计科目
  • 红字发票如何做账
  • 外聘专家费用标准
  • 外地工程预缴的工资怎么做账务处理
  • 交易费用计入何种科目
  • 简易计税项目的进项税能抵一般项目的销项税额吗?
  • 非同一控制下企业合并,企业合并成本包括
  • 物业安装摄像头的规定
  • 原材料采用实际成本法,在会计核算上应设置的账户是
  • 租赁出租人分录
  • 美容行业如何做好管理工作
  • 小规模企业能否消化13点增值税普通发票
  • 往来是啥意思
  • 总资产周转率多少算正常
  • 生产成本如何设置明细账
  • sql server错误和使用情况报告
  • version 2什么意思
  • win8分盘怎么分
  • 在linux系统中命令
  • windows疑难解答在哪里
  • win8n
  • win10画图功能
  • jquery layout 布局
  • android应用程序开发的流程
  • 修改cmd中显示的用户名!
  • jquery遍历li
  • 在javascript中什么方法可以对数组元素进行排序
  • js中unbind
  • javascript面向对象编程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设