MongoDB
 sql >> Base de Dados >  >> NoSQL >> MongoDB

A atualização simultânea do MongoDB para o mesmo documento não está se comportando atômica


Use atualizações condicionais e examine o número de documentos atualizados para ver se a atualização aconteceu.
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