【发布时间】: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