python - pymongo 含有子条件的操作 应该怎么写?
本文介绍了python - pymongo 含有子条件的操作 应该怎么写?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
mongodb pymongo:
有两条记录是这样
{"a":"AAA" , "b":[ {"b11": "b11value" ,"b12":"b12value"} , { "b21":"b21value" , "b22":"b22value" } ]}
{"a":"BBB" , "b":[ {"b11": "b11value" ,"b12":"b12value"} , { "b21":"b21value" , "b22":"b22value" } ]}
我想更新a为AAA且b中b11的值为b11value的值为b11111111value:
结果应该是这样:
{"a":"AAA" , "b":[ {"b11": "b11111111value" ,"b12":"b12value"} , { "b21":"b21value" , "b22":"b22value" } ]}
{"a":"BBB" , "b":[ {"b11": "b11value" ,"b12":"b12value"} , { "b21":"b21value" , "b22":"b22value" } ]}
以及把a为AAA且b中b11的值为b11value的(b11删除)
结果应该是这样:
{"a":"AAA" , "b":[ { "b21":"b21value" , "b22":"b22value" } ]}
{"a":"BBB" , "b":[ {"b11": "b11value" ,"b12":"b12value"} , { "b21":"b21value" , "b22":"b22value" } ]}
一个更新,一个是删除
这两个怎么写?
sql语句应该怎么写?谢谢
解决方案
例子里c
为你的集合名。
第一个:
db.c.update(
{'a': 'AAA', 'b': {'$elemMatch': {'b11': 'b11value'}}},
{'$set': {'b.$.b11': 'b11111111value'}})
第二个:
db.c.update(
{'a':'AAA'},
{'$pull': {'b': {'b11': 'b11111111value'}}})
用到了$elemMatch
,$set
,$pull
三个修改器。
这篇关于python - pymongo 含有子条件的操作 应该怎么写?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文