sql >> Database >  >> NoSQL >> MongoDB

MongoDB gelijktijdige update naar hetzelfde document gedraagt ​​zich niet atomair

Gebruik voorwaardelijke updates en bekijk het aantal bijgewerkte documenten om te zien of de update heeft plaatsgevonden.

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




  1. Koppelen en maken van MongoDB-joins met SQL:deel 1

  2. Hoe een Google Compute Engine-instantie doorsturen?

  3. JavaScript - Hoe een datum op te slaan in MongoDB-document in ISODate-formaat?

  4. MongoDB Norm-query geneste objecten