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 shell 中是否正常工作?

于 2012-02-21T21:40:43.590 回答
2

位置操作符是 mongodb 原子更新内部的东西,所以简单的原子更新和使用位置操作符更新没有区别。

c# 中上述 mongo shell 语法的等价物是:

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 回答