MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

La mise à jour simultanée de MongoDB vers le même document ne se comporte pas de manière atomique

Utilisez des mises à jour conditionnelles et examinez le nombre de documents mis à jour pour voir si la mise à jour a eu lieu.

require 'mongo'

client = Mongo::Client.new(['localhost:14400'])

coll = client['coll']

coll.delete_many
coll.insert_one(foo: 1)

rv = coll.update_one({foo: 1}, '$set' => {foo: 2})
if rv.modified_count == 1
  puts 'Updated'
end

rv = coll.update_one({foo: 1}, '$set' => {foo: 2})
if rv.modified_count == 1
  puts 'Updated'
end

https://github.com/p -mongo/tests/blob/master/query-conditional-update/test.rb