当前位置:首页 >热点 >一日一技:在 MongoDB 中,如何批量更新不同数据为不同值? 一日一技:在 MongoDB 中

一日一技:在 MongoDB 中,如何批量更新不同数据为不同值? 一日一技:在 MongoDB 中

2024-06-29 07:23:28 [百科] 来源:避面尹邢网

一日一技:在 MongoDB 中,日技如何批量更新不同数据为不同值?

作者:kingname 运维 数据库运维 MongoDB update_one是中值更新第一条满足查询条件的数据;update_many是更新所有满足查询条件的数据。大家在使用update_many的何批时候,不知道有没有想过一个问题:update_many会对所有满足条件的量更文档更新相同的字段。

[[406228]]

我们知道,同数当使用 Pymongo 更新MongoDB 字段的不同时候,我们有两种常见的日技方法:

一日一技:在 MongoDB 中,如何批量更新不同数据为不同值? 一日一技:在 MongoDB 中

  1. handler.update_one({ 'name': 'value'}, { '$set': { 'aa': 'bb'}}) 
  2. handler.update_many({ 'name': 'value'}, { '$set': { 'aa': 'bb'}}) 

其中,update_one是中值更新第一条满足查询条件的数据;update_many是更新所有满足查询条件的数据。大家在使用update_many的何批时候,不知道有没有想过一个问题:update_many会对所有满足条件的量更文档更新相同的字段。例如,同数对于上面第二行代码,不同所有name字段为value的日技数据,在更新以后,中值新的何批数据的aa字段的值全都是bb。那么,有没有办法一次性把不同的字段更新成不同的数据呢?

一日一技:在 MongoDB 中,如何批量更新不同数据为不同值? 一日一技:在 MongoDB 中

例如,我们的 MongoDB 中有如下数据:

一日一技:在 MongoDB 中,如何批量更新不同数据为不同值? 一日一技:在 MongoDB 中

sidnamesexresultis_qualified
1王晓一80true
2张小二69false
3刘小三76false
4朱小四75true
5马小五50false
6赵小六77true
7钱小七60false
8孙小八68false
9李小九98true
10周小十61false

假设这是一份成绩表,一开始,要求男生不低于80分,女生不低于70分,is_qualified字段才会为True。后来改了计分规则,变成男生不低于90分,女生不低于60分,is_qualified就能为 True,否则为 False。所以现在需要批量更新数据。显然,对男生而言,有一些原本为True的需要变成 False;对女生而言,有一些原本为 False 的,要变成 True。如果让你直接使用update_many,你可能需要写成两条更新语句:

  1. handler.update_many({ 'sex': '男', 'result': { '$lt': 90}}, { '$set': { 'is_qualified': False}}) 
  2.  
  3. handler.update_many({ 'sex': '女', 'result': { '$gte': 60}}, { '$set': { 'is_qualified': True}}) 

那有没有办法只发一次请求,就同时更新两组数据呢?其实方法也是有的,就是bulk_write:

  1. import pymongo 
  2.  
  3. handler = pymongo.MongoClient().test_db.test_col 
  4.  
  5. handler.bulk_write([ 
  6.   pymongo.UpdateMany({ 'sex': '男', 'result': { '$lt': 90}}, { '$set': { 'is_qualified': False}}), 
  7.   pymongo.UpdateMany({ 'sex': '女', 'result': { '$gte': 60}}, { '$set': { 'is_qualified': True}}) 
  8. ]) 

bulk_write接收一个列表作为参数。这个列表里面的每一个元素是一个pymongo.X对象,这里的 X 可能是InsertOne/InsertMany/DeleteOne/DeleteMany/UpdateOne/ UpdateMany……,基本上就是你想使用的对应操作的驼峰命名法形式。

这种方式,Pymongo 会在一次请求同时提交这两组操作,减少网络连接的时间消耗。

批量操作不仅支持UpdateOne,还支持各种其他操作,你可以阅读Bulk Write Operations — PyMongo 3.11.4 documentation[1]。

参考资料

[1]Bulk Write Operations — PyMongo 3.11.4 documentation: https://pymongo.readthedocs.io/en/stable/examples/bulk.html

 

责任编辑:武晓燕 来源: 未闻Code MongoDB数据

(责任编辑:休闲)

    推荐文章
    热点阅读