2016-10-11 15 views
1

私は、この文書更新組み込みのMongoDBを使用してフィールドとC#

{ "_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.widで検索するとWatchtbl.nameとWatchtbl.Symbolesを更新しようとするので、私はちょうどに開始しよう名前、この私のコード:

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); 

しかし、何も起こりません、エラーはありません。 Watchtbl.Symbolesを更新しようとするよりも、同じコードを2回実行する必要があります。同時にすべてを更新する別の方法はありません。私はこの部分を削除した場合、仕事や更新名を、

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

しかし、私はSymbolesを更新する必要があり、私はこのエラーメッセージが表示されます

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); 

を更新する1つの項目で

ソリューション

重大度コード説明プロジェクトファイルの行の抑制状態 エラーCS1660ラムダ私はBSONを更新する必要がある場合は、\ Users \ユーザーamin- \デスクトップ\ FinalWatchTbl \ FinalWatchTbl \ UpdateFrm.cs 117アクティブ

ソリューション :それはデリゲート型FinalWatchTbl Cではありませんので、 'のFieldDefinition' と入力する式"。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); 

答えて

2

検索方法はupdate documents in an array using the positional operatorです。

// 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); 
+0

urコードが機能していない、配列を更新する必要がある、私はすでに名前を更新しています。 – Juste3alfaz