sql >> Base de Datos >  >> NoSQL >> MongoDB

La actualización simultánea de MongoDB al mismo documento no se comporta de forma atómica

Use actualizaciones condicionales y examine la cantidad de documentos actualizados para ver si ocurrió la actualización.

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-condicional-update/test.rb