1

我尝试了很多方法来更新现有的 bson 文档,但它在我的 mongodb 中从未改变:

col = db["collection"]
col.insert({"ben": 1})
doc = col.find().to_a.first
# => {"_id"=>BSON::ObjectId('556c7f1b167e70640070a4d9'), "ben"=>1}

第一次尝试更新:

doc.merge!({"ben": 5, "ams": 6})
col.find().to_a.first
# => {"_id"=>BSON::ObjectId('556c7f1b167e70640070a4d9'), "ben"=>1}

第二次尝试更新:

doc.update({"ben": 5, "ams": 6})
col.find().to_a.first
# => {"_id"=>BSON::ObjectId('556c7f1b167e70640070a4d9'), "ben"=>1}

第三次尝试……

doc["ben"] = 5
doc["ams"] = 6
doc.save
# NoMethodError: undefined method `save' for #<BSON::Document:0x00000003f284d0>

如您所见,以上都不适合我。我无法通过谷歌搜索找到任何其他建议。你知道如何更新我的文件吗?是否可以?

4

1 回答 1

2

一旦你这样做:

col.find().to_a
#          ^^^^

您正在使用与数据库没有连接的简单 Ruby 哈希数组。所以当你说:

doc.update({"ben": 5, "ams": 6})

你在打电话Hash#update。如果你想更新一些东西,你会调用返回update的内容find

col.find.update(:$set => { 'ben' => 5, 'ams' => 6 })

或者如果您想替换整个文档:

col.find.update('ben' => 5, 'ams' => 6)

当然,您通常会告诉您想要find哪个特定文件。

请注意,update仅更新它找到的第一个匹配文档,如果要更新所有匹配文档,则使用update_all.

于 2015-06-01T16:54:10.653 回答