【问题标题】:MongoDB updateMany with Conditional带有条件的 MongoDB updateMany
【发布时间】:2019-05-12 11:59:17
【问题描述】:

我有一个很大的数据库,里面有各种不一致的地方。我要澄清的一项是根据人口更改国家/地区状态。

数据样本是:

{ "_id" : "D", "name" : "Deutschland", "pop" : 70000000, "country" : "Large Western" }
{ "_id" : "E", "name" : "Eire", "pop" : 4500000, "country" : "Small Western" }
{ "_id" : "G", "name" : "Greenland", "pop" : 30000, "country" : "Dependency" }
{ "_id" : "M", "name" : "Mauritius", "pop" : 1200000, "country" : "Small island"}
{ "_id" : "L", "name" : "Luxembourg", "pop" : 500000, "country" : "Small Principality" }

显然,我想根据人口规模将国家/地区字段更改为更统一的内容。

我已经尝试过这种方法,但显然缺少一些与国家/地区字段更新相关联的方法。

db.country.updateMany( { case : { $lt : ["$pop" : 20000000] }, then : "Small country" }, { case : { $gte : ["$pop" : 20000000] }, then : "Large country" }

编辑:在我写完之前发布。

我正在考虑使用 $cond 功能,基本上返回如果为真,则执行 X,如果为假,则执行 y,同时使用 updateMany。

这可能吗,还是有解决方法?

【问题讨论】:

  • 您希望 bulkWrite() 在其中使用 两个 "updateMany" 语句。聚合表达式不能用于任何形式的update语句中的“交替选择”。
  • bulkwrite() 我将如何在这里使用它?
  • 基本上是db.country.bulkWrite([{ "updateMany": { "filter": { "pop": { "$lt": 20000000 } }, "update": { "$set": { "country": "Small Country" } } }},{ "updateMany": { "filter": { "pop": { "$gt": 20000000 } }, "update": { "$set": { "country": "Large Country" } } }}])。与bulkWrite() 上的记录差不多
  • 仅供参考 SERVER-6566 已经存在很长时间了。这仍然不是真正需要任何人确定的东西,并且此类请求是在引入“批量”API 之前提出的。所以有这个和其他一些功能可以缓解各种突出的 JIRA 问题。只需在一个请求中执行 两个 写入,而不是“有条件地”写入。
  • 你是对的。比长 cmets 作为答案更好。我最初只是作为评论写的,因为我假定已经存在类似的答案。事实证明它没有。真可惜,因为这似乎是一个相当普遍的问题。

标签: mongodb mongodb-query


【解决方案1】:

您真的希望 bulkWrite() 在其中使用两个 "updateMany" 语句。聚合表达式不能用于任何形式的更新语句中的“交替选择”。

db.country.bulkWrite([
  { "updateMany": {
    "filter": { "pop": { "$lt": 20000000 } },
    "update": { "$set": { "country": "Small Country" } }
  }},
  { "updateMany": {
    "filter": { "pop": { "$gt": 20000000 } },
    "update": { "$set": { "country": "Large Country" } } 
  }}
])

SERVER-6566 上仍有一个针对“条件语法”的未完成的“功能请求”,但尚未解决。 “批量” API 实际上是在提出此请求后引入的,并且确实可以适应,如图所示,或多或少做同样的事情。

另外在聚合语句中使用$out 不是“更新” 的选项,目前只能写入“新集合”。从 MongoDB 4.2 开始的预定更改将允许 $out 实际上“更新”一个现有的集合,然而这只会是集合的位置要更新的集合不同于从聚合管道收集数据时使用的任何其他集合。因此,不可能使用聚合管道更新与您正在读取的内容相同的集合

简而言之,使用bulkWrite()

【讨论】:

    猜你喜欢
    • 2019-01-07
    • 2015-11-30
    • 2021-12-23
    • 2018-04-07
    • 2020-11-06
    • 1970-01-01
    • 2021-08-29
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多