Как использовать позиционный оператор MongoDB в коде C#?
Я хочу использовать позиционный оператор 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 ответа
Вы написали бы это в 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);
Это кажется опасным обновлением; Вы перезаписываете уличный адрес только на основании совпадения города? Правильно ли работает запрос в оболочке Монго?
Позиционный оператор является внутренним элементом атомарных обновлений 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);