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

Aktualizacja słownika w Mongodb

Nie wiem, czego dokładnie chcesz. W MongoDB istnieją zasadniczo dwa rodzaje aktualizacji:można wykonać atomową aktualizację lub zamień dokument .

Zastąpienie dokumentu jest często łatwiejsze , ponieważ pozwala używać standardowych operacji C# do wykonywania modyfikacji i ponownie ocenia wygenerowane właściwości i tym podobne:

var user = new User { Name = "John Doe", Quests = 
   new Dictionary<string, Tuple<string, string>> { 
       { "hoho", new Tuple<string, string>("A", "A-Item") } } };
users.InsertOneAsync(user).Wait();
user.Quests = new Dictionary<string, Tuple<string, string>> { 
       { "hoho Modified", new Tuple<string, string>("B", "B-Item") } };
users.ReplaceOneAsync(p => p.Id == user.Id, user);

Jednak czasami wymagane jest użycie modyfikatorów atomowych, takich jak $push , $pull , $set , $addToSet , itp. z powodu obaw o współbieżność. Generalnie uważam, że wykonywanie w ten sposób złożonych operacji na złożonych obiektach osadzonych jest złym pomysłem, ponieważ istnieje duże prawdopodobieństwo spójności obiektu (w sensie ACID, czyli „niezmienniki obiektu” ) nie można sprawdzić.

Załóżmy, że użytkownik nie powinien mieć jednocześnie więcej niż 3 aktywnych zadań, kto zapewnia przestrzeganie tej zasady? Jest to zwykle odpowiedzialność kodu, a złożone niezmienniki nie mogą być sprawdzane przez bazę danych.

Jeśli nadal chcesz używać tych operatorów atomowych, sugeruję zadanie nowego pytania, ponieważ tak naprawdę zależy to od szczegółów (słownik domyślnie jest serializowany jako dokument, krotka jako tablica i wymagają różnych modyfikatorów atomowych w MongoDB). Na przykład, aby dodać nowy element do słownika, użyj $set :

users.UpdateOneAsync(p => p.Id == user.Id, 
  Builders<User>.Update.Set("Quests.hoho Modified", 
     new Tuple<string, string>("B", "B-Item")));



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Odpowiednik MongoServer.State w sterowniku 2.0

  2. MongoDB:Jak zaktualizować pojedynczy element podrzędny w tablicy, do którego odwołuje się indeks w tablicy?

  3. MongooseError — Przekroczono limit czasu buforowania operacji `users.findOne()` po 10000 ms

  4. Mongoexport przy użyciu ograniczeń $gt i $lt w zakresie dat

  5. Jak używać $elemMatch do projekcji agregatu?