pymongo查询列表元素_pymongo与mongodb 如何更新数组中所有符合条件的元素【详细讲解】...

{

"_id" : ObjectId("5de0c88a0f158bf0f60ff99a"),

"province" : "陕西",

"cityAndData" : [

{

db.weather.update(

{'province':'陕西','cityAndData.city':'西安','cityAndData.districtAndData.district':'长安'},

{$push: {"cityAndData.$.districtAndData.$[d].dateTimeAndData":'mydata'}},

{arrayFilters:[{'c.city':'西安'},{'d.district':'长安'}],upsert:false})

"city" : "西安",

"districtAndData" : [

{

"district" : "长安",

"dateTimeAndData" : []

},

{

"district" : "临潼",

"dateTimeAndData" : []

}

]

},

{

"city" : "咸阳",

"districtAndData" : [

{

"district" : "咸阳",

"dateTimeAndData" : []

},

{

"district" : "三原",

"dateTimeAndData" : []

}

}

]

}

需求:找出陕西省西安市长安区的dateTimeAndData属性中,插入一条数据 ‘mydata’

在mongodb shell中:

$[]和arrayFilters配合起来使用,$是占位符,意思是在cityAndData数组的元素中,找到满足arrayFilters中对应过滤条件的元素,参考mongodb-identifier,注意要求mongodb版本号3.6及以上。如下,就能将’mydata’插入到dateTimeAndData中

db.weather.update(

{'province':'陕西','cityAndData.city':'西安','cityAndData.districtAndData.district':'长安'},

{$push: {"cityAndData.$.districtAndData.$[d].dateTimeAndData":'mydata'}},

{arrayFilters:[{'c.city':'西安'},{'d.district':'长安'}],upsert:false})

在pymongo中:

update方法已经逐渐废弃了。最好用update_one或者update_many,取决于你想更新一条还是多条符合条件的记录

self.mycol.update_one(

dataUpdateQuery,

{'$push'{'cityAndData.$.districtAndData.$[d].dateTimeAndData': dateTimeAndData}},

upsert=False,

array_filters=[{'c.city':city},{'d.district':district}])

为了看清楚分了几行写,注意upsert=False,不要用“:”代替“=”;array_filters也是作为参数出现的,不要加“”

其实看看官网的api就一目了然了(参考pymongo-update_one):

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值