Как использовать позиционный оператор MongoDB в коде C #? - PullRequest
3 голосов
/ 21 февраля 2012

Я хочу использовать позиционный оператор MongoDB в коде C #. Вот структура данных для Клиента:

{ 
  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.

Ответы [ 2 ]

4 голосов
/ 22 февраля 2012

Вы написали бы это в 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?

1 голос
/ 22 февраля 2012

Позиционный оператор является внутренним элементом атомарных обновлений mongodb, поэтому нет никакой разницы для простого атомарного обновления и обновления с помощью позиционного оператора.

Эквивалент вышеупомянутого синтаксиса оболочки монго в c # будет:

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