MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Równoczesna aktualizacja MongoDB do tego samego dokumentu nie działa atomowo

Użyj aktualizacji warunkowych i sprawdź liczbę zaktualizowanych dokumentów, aby sprawdzić, czy nastąpiła aktualizacja.

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. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Mongo uruchamiania PHP:Nie można zainicjować modułu

  2. połączyć się z instancją mongodb bez --authenticationDatabase admin

  3. Jak działa przykład zliczania wiadomości w dokumentach Meteor?

  4. Jak ustawić nazwę @TextIndex w encji z Spring-Data-MongoDB?

  5. Jak używać GridFS do przechowywania obrazów przy użyciu Node.js i Mongoose?