位置: 编程技术 - 正文

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

  • 待转销项税额是几级科目
  • 内蒙古注册税务师协会
  • 房地产中介门头
  • 增值税专用发票抵扣税额是什么意思
  • 增值税普票税额怎么算出来的
  • 建筑工程发票来自哪里
  • 待抵扣进项税额是什么意思
  • 发票上盖财务章吗
  • 红字发票科目入进项税额还是进项税额转出
  • 外币投入的资本
  • 外购产品对外捐赠的会计处理
  • 驾驶培训费可以报销吗
  • 进项税额转出会影响利润吗
  • 税务与审计调整结果不一致该如何调整?
  • 个体户增值税怎么算
  • 专用发票的有效期是几年
  • 快递公司税收优惠
  • 零申报的企业所得税年报怎么填
  • 加盟商的作用
  • 公司汽车一年可以用多少油费
  • 法人向公司借款用途怎么写
  • 机动车抵扣联是什么
  • 一般纳税人进项税额转出会计分录
  • 企业老板机票怎么报销记账
  • PHP+jQuery+Ajax实现分页效果 jPaginate插件的应用
  • PHP CURL或file_get_contents获取网页标题的代码及两者效率的稳定性问题
  • ghost后分区没有了
  • php数组操作
  • 定额发票收入怎么样确定
  • PHP:stream_get_meta_data()的用法_Stream函数
  • 什么是摊余成本计量的金融资产
  • 手机短信是哪一年开始的
  • 污水处理厂能享受补助吗
  • 小规模企业购入固定资产怎么做账务处理
  • php数组数据结构
  • 纳汉双语
  • 解决php程序运行问题
  • ssh非交互式登录
  • php新版本特性
  • halt关机命令
  • 进项税额转出有什么好处
  • 购买方怎么填写发票
  • 增值税加计抵减最新政策2022
  • 个人独资企业计提的各种准备金支出不得扣除
  • 增值税免税优惠梳理
  • 走账犯罪吗
  • 品种法分批法分步法的区别
  • 坏账准备计提要求
  • 三证合一办理流程及费用
  • 房地产企业何时确认收入结转成本
  • 营改增后营业费用科目还有吗
  • 临时设施属于什么科目
  • 销售预算的重要性
  • sql解析原理
  • mysql时间语句
  • 由于这台计算机没有远程客户端访问许可证
  • 安装fedora进入不到安装界面
  • wintogo.exe
  • 忘记密码 ?
  • ubuntu怎么用linux
  • 苹果Mac系统怎么切换输入法
  • Linux桌面环境安装
  • 在linux中使用什么命令可以执行shell脚本
  • win7系统怎么设置浏览器主页
  • 微软为什么这么贵
  • cocos2d-x 3.3 final 适配安卓5.0机型小记
  • 图文详解地理图册电子版
  • python安装pip.whl
  • 关于javascript
  • linux 定时任务
  • python中类怎么用
  • unity脚本编写教程
  • jquery实现移动端
  • jquery返回顶部代码
  • 国家税务局涉税信息公开
  • 税务财务负责人承担什么责任
  • 河南省教育厅纪检组举报电话
  • 黑龙江省国税局网站
  • 季度申报表如何填写
  • 逆光代售和神仙代售那个好一点
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设