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

Запитване, филтриране и актуализиране на вложени масиви от множество нива в MongoDB с помощта на C#

Трябва да използвате $[] многопозиционен оператор, ще се опитам да напиша какво трябва да използвате за кода, който сте поставили:

var baseFilter = Builders<Project>.Filter.Eq("ProjectID": 1);
var update = Builders<Project>.Update.Set("ProjectTasks.$[i].Comments.$[j].CommentDescription", comment.CommentDescription);

var arrayFilters = new List<ArrayFilterDefinition>
{
    /* change the type names here if they have different names, I just guessed */
    new BsonDocumentArrayFilterDefinition<ProjectTask>(new BsonDocument("i.ProjectTaskID", projectTaskID)),
    new BsonDocumentArrayFilterDefinition<Comment>(new BsonDocument("j.CommentId", commentID))
};

var updateOptions = new UpdateOptions { ArrayFilters = arrayFilters };

await Collection.UpdateOneAsync(baseFilter, update, updateOptions);


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Loopback ValidationError:Екземплярът „Role“ не е валиден. Подробности:„име“ вече съществува (стойност:admin)

  2. Отхвърлен анализатор на тялото?

  3. Валидаторът на Mongo Json Schema AnyOf не работи

  4. как да добавя стойност към горната част на масив в mongodb?

  5. $project в $lookup mongodb