学无先后,达者为师

网站首页 编程语言 正文

mongoDB复杂查询实例(嵌套多个数组和正则表达式使用)

作者:大王我亲自来巡山 更新时间: 2022-07-12 编程语言

需求

直接上图:
现在需求是,在mongo数据库中,查找数据库名为:”nrp_matedata_dev“,collection(数据库表)名为:richPage,dataSources数组下的object对象:”stct“,”stct“对象下的数组:views,views数组下的对象:metricView,metricView对象下的字段:domain,并且,要求domain字段是由“Caleb”开头的。
请添加图片描述

mongo shell查询语句

db.getCollection('richPage').find({"dataSources":{$elemMatch:{"stct.views":{$elemMatch:{"metricView.domain":{$regex:"Caleb",$options:"$i"}}}}}})

解释一下几个点
$elemMatch:用来表示数组,如果要查询的是数组中的某个,就需要用这个,比如dataSources是个数组,因此:

"dataSources":{$elemMatch:{xxx:xxx}}

对于object:表示对象的某个属性的,可以直接使用“.”,比如,stct下的view:

"stct.views":

正则$regex:关键字regex后面可以匹配正则,正则规则自己百度搜吧,没必要记

原文链接:https://blog.csdn.net/weixin_43923436/article/details/125624686

栏目分类
最近更新