需求
直接上图:
现在需求是,在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后面可以匹配正则,正则规则自己百度搜吧,没必要记