使用MongoDb和c#更新嵌入式字段

本文关键字:嵌入式 字段 更新 MongoDb 使用 | 更新日期: 2023-09-27 18:12:24

我有这个文档

    { "_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和watchtable搜索。扩展并更新watchtable .name和watchtable .name。符号,所以我试着从名字开始,这是我的代码:

    var collectionWatchtbl = _database.GetCollection<BsonDocument>("UsersWatchtbls");
    var filter = Builders<BsonDocument>.Filter.Eq("_id", id) & 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);

但是什么也没有发生,甚至没有错误。然后如果我尝试更新watchtable。符号,我必须做两次相同的代码,没有其他方法可以同时更新所有。

只有一项更新的解决方案

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) && 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无法将lambda表达式转换为类型'FieldDefinition',因为它不是委托类型FinalWatchTbl c:' users 'amin ' desktop' FinalWatchTbl'FinalWatchTbl'UpdateFrm.cs 117 Active

<

解决方案/strong>如果我需要将bson数组更新为嵌套文档,它可以使用

"Watchtbl .Symboles美元。"所以解决方案是:

BsonArray arrSym = new BsonArray();
            var filter = Builders<UserWatchTblCls>.Filter.Where(x => x.Id == ObjectId.Parse(id) && 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);

使用MongoDb和c#更新嵌入式字段

查找如何使用位置操作符更新数组中的文档。

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