Обновить встроенное поле с помощью MongoDB и C#

#c# #mongodb

#c# #mongodb

Вопрос:

У меня есть этот документ

     { "_id" : ObjectId("57f65ed25ced690b5408a9d1"), "fbId" : "7854", "Name" : "user1", "pass" : "user1", "Watchtbl" : [ { "wid" : "745", "name" : "azs", "Symboles" : [ { "Name" : "nbv" } ] }, { "wid" : "8965", "name" : "bought stock1", "Symboles" : [ { "Name" : "AAA" }, { "Name" : "BSI" }, { "Name" : "EXXI" }, { "Name" : "AMD" } ] }, { "wid" : "9632", "name" : "bought stock3", "Symboles" : [ { "Name" : "AAA" }, { "Name" : "AMD" } ] } ] }
  

Я пытаюсь выполнить поиск по _id и Watchtbl.расширьте и обновите Watchtbl.name и Watchtbl.Символы, поэтому я стараюсь просто начинать с name, это мой код:

     var collectionWatchtbl = _database.GetCollection<BsonDocument>("UsersWatchtbls");
    var filter = Builders<BsonDocument>.Filter.Eq("_id", id) amp; Builders<BsonDocument>.Filter.Eq("Watchtbl.wid", wid );
    var update = Builders<BsonDocument>.Update.Set("Watchtbl.name", NameComboBox.SelectedItem.ToString());
    var result = await collectionWatchtbl.UpdateOneAsync(filter, update);
  

Но ничего не происходит, даже ошибки нет.
и чем, если я попытаюсь обновить Watchtbl.Символы, должен ли я выполнять один и тот же код дважды, другого способа обновить все одновременно нет.

Решение с 1 элементом для обновления

 BsonArray arrSym = new BsonArray();
            foreach (var item in SymbolesListBox.SelectedItems)
            {
                arrSym.Add(new BsonDocument("Name", item.ToString()));
            }

            var filter = Builders<UserWatchTblCls>.Filter.Where(x=> x.Id == ObjectId.Parse(id) amp;amp; x.WatchTbls.Any(i=> i.WID == wid) );
            var update = Builders<UserWatchTblCls>.Update.Set(x=> x.WatchTbls[-1].Name, NameComboBox.SelectedItem.ToString()).Set(x => x.WatchTbls[-1].Symbols, arrSym);
            await collectionWatchtbl.UpdateManyAsync(filter, update);
  

Если я удалю эту часть, будет работать и обновлять имя,

 .Set(x => x.WatchTbls[-1].Symbols, arrSym)
  

Но мне нужно обновить символы, и я получаю эту ошибку

Описание кода серьезности Ошибка состояния подавления строки файла проекта CS1660 Не удается преобразовать лямбда-выражение в тип ‘FieldDefinition’, поскольку оно не является типом делегата FinalWatchTbl C:Usersamin-DesktopFinalWatchTblFinalWatchTblUpdateFrm.cs 117 Активных

Решение, если мне нужно обновить массив bson во вложенный документ, с которым он работает

«Watchtbl. $.Symboles» таким образом, решение :

 BsonArray arrSym = new BsonArray();

            var filter = Builders<UserWatchTblCls>.Filter.Where(x => x.Id == ObjectId.Parse(id) amp;amp; x.WatchTbls.Any(i => i.WID == wid));
            var update = Builders<UserWatchTblCls>.Update.Set(x => x.WatchTbls[-1].Name, NameComboBox.SelectedItem.ToString()).Set("Watchtbl.$.Symboles", arrSym);
            //var update = Builders<UserWatchTblCls>.Update.Set("Watchtbl.$.Symboles", arrSym);
            await collectionWatchtbl.UpdateManyAsync(filter, update);
  

Ответ №1:

Найдите, как обновить документы в массиве с помощью позиционного оператора.

   // string id, int wid ...
  var fdb = Builders<BsonDocument>.Filter;
  var udb = Builders<BsonDocument>.Update;
  var filter = fdb.Eq("_id", id) amp; fdb.ElemMatch ("watchtbl", fdb.Eq ("wid", wid));
  var update = udb.Set("watchtbl.$.name", name);
  collectionWatchtbl.UpdateOne(filter, update);
  

Комментарии:

1. ваш код не работает, кроме того, мне нужно обновить массив, я уже обновил имя.