MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

Вземете и добавете/актуализирайте многостепенен вграден/вложен MongoDB документ с помощта на C#

Според документация :

И така, използвайки -1 не е път напред тук. Подходът, който трябва да предприемете, е $ позиционно филтриран оператор .

В C# няма строго типизирано представяне, така че вашият код може да изглежда по следния начин:

var filter = Builders<Channel>.Filter.Eq(x => x.Id, "5e4606e6ae7b090688671416");

var like = new Like() {Name = "new like", Id = "1"};
var episodeId = "5e46071d385a672b0cea0f86";
var trackId = "5e460dbe2bc5e70c9cfeac21";

var update = Builders<Channel>.Update.Push("Episodes.$[e].Tracks.$[t].Likes", like);

var arrayFilters = new List<ArrayFilterDefinition>();
ArrayFilterDefinition<BsonDocument> episodesFilter = new BsonDocument("e._id", new BsonDocument("$eq", episodeId));
ArrayFilterDefinition<BsonDocument> tracksFilter = new BsonDocument("t._id", new BsonDocument("$eq", trackId));
arrayFilters.Add(episodesFilter);
arrayFilters.Add(tracksFilter);

var updateOptions = new UpdateOptions { ArrayFilters = arrayFilters };

var result = mongoDBCollection.UpdateOne(filter, update, updateOptions);



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Преобразуване на някои полета в Mongo от String в Array

  2. Mongoid не е под въпрос

  3. Премахване на последния документ от Mongo DB в една заявка

  4. Mongoose - RangeError:Максималният размер на стека от обаждания е превишен

  5. $ проекция в mongoDB findOneAndUpdate()