嵌套查询和嵌套结果有什么区别_MongoDB嵌套查询

最近刚接触mongodb,需要取出一个嵌套文档中的值,网上查询的各种解决方案都是需要解析json,mongodb官网文档也没找到哪里有说明。

经过尝试,发现可以如下查询

collection数据如下:

{ "_id" : ObjectId("5880b72ce4b02c3ae10549b8"), "segments" : { "HKGBKK" : { "airline" : "HX", "cabinCodeMap" : {  } } }, "timestamp" : NumberLong("1484830508116") }
{ "_id" : ObjectId("5880b72ce4b02c3ae10549b9"), "segments" : { "HKGBKK" : { "airline" : "HX", "cabinCodeMap" : {  } } }, "timestamp" : NumberLong("1484830508117") }
{ "_id" : ObjectId("58818b8de4b02c3ae10549ba"), "segments" : { "CANSEL" : { "airline" : "CZ", "timestamp" : NumberLong("1484884877858") }

需要取出segments中HKGBKK下的airline的vaule为HX的记录,执行如下:

> db.collection.find({'segments.HKGBKK.airline':'HX'}).limit(2)
{ "_id" : ObjectId("5880b72ce4b02c3ae10549b8"), "segments" : { "HKGBKK" : { "airline" : "HX", "cabinCodeMap" : {  } } }, "timestamp" : NumberLong("1484830508116") }
{ "_id" : ObjectId("5880b72ce4b02c3ae10549b9"), "segments" : { "HKGBKK" : { "airline" : "HX", "cabinCodeMap" : {  } } }, "timestamp" : NumberLong("1484830508117") }

既然可以通过嵌套查询出记录,那么类似的,应该也可以修改嵌套数据,由于查询的是业务数据库,此处不提供具体例子,后续自己测试时有结果再补充:)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值