ホームページ  >  に質問  >  本文

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语句应该怎么写?谢谢

伊谢尔伦伊谢尔伦2741日前510

全員に返信(1)返信します

  • 迷茫

    迷茫2017-04-18 10:27:30

    この例では、c はコレクション名です。 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

    最初の1つ:🎜 リーリー 🎜2番目: 🎜 リーリー 🎜3 つの修飾子が使用されます: $elemMatch$set、および $pull。 🎜

    返事
    0
  • キャンセル返事