3

C#コードでMongoDBの位置演算子を使用したいと思います。お客様のデータ構造は次のとおりです。

{ 
  name:"Robert", 
  age:40, 
  addresses:[ 
    {street:"...", city:"New York", country:"USA", ...}, 
    {street:"...", city:"California", country:"USA", ...},
  ],
}

したがって、ニューヨーク市の住所である通りの値を更新する場合は、MongoDBで次のクエリを使用します。

db.customer.update(
   { "addresses.city" : "New York"}, 
   { $set : {
       "addresses.$" : {"street":"New street", city:"New York", country:"USA",...}
   } }, false, true);

C#コードで使用する同等のクエリは何ですか?C#コードで位置演算子を使用するにはどうすればよいですか?

公式のMongoDBドライバーを使用しています。

4

2 に答える 2

4

これをC#で次のように記述します。

var newAddress = new BsonDocument
{
    { "street", "New street" },
    { "city", "New York" },
    { "country", "USA" }
    // ...
};
var query = Query.EQ("addresses.city", "New York");
var update = Update.Set("addresses.$", newAddress);
var result = customerCollection.Update(query, update, UpdateFlags.Multi);

これは危険な更新のように思えます。都市のマッチングのみに基づいて住所を上書きしていますか?クエリはmongoシェルで正しく機能していますか?

于 2012-02-21T21:40:43.590 に答える
2

位置演算子はmongodbアトミック更新の内部的なものであるため、単純なアトミック更新と位置演算子による更新に違いはありません。

上記のc#でのmongoシェル構文に相当するものは次のとおりです。

var collection = database.GetCollection<Customer>("customer");
var searchQuery = Query.EQ("addresses.city", "New York");
var address = new Address()
{
  street = "New street",
  city = "New York",
  country = "USA"
};
var update = Update.Set("addresses.$", address.ToBsonDocument())
collection.Update(searchQuery, update, UpdateFlags.Multi);
于 2012-02-21T21:38:19.920 に答える