**更新了更多代码:
我有一个类似于
的类/实体public class price
{
public decimal mrp { get; set; }
}
这是以下复杂文档的一部分:
{
"Name" : "Name",
"_id" : ObjectId("522a83c2a833e20db4b028ea"),
"price" : {
"mrp" : 599,
}
}
我正在使用c#驱动程序更新此文档...如下所示:
//用于检查doc中是否存在字段 private bool check_field(BsonDocument doc,string field_name) { if(doc.Contains(field_name)) { 返回true; } 其他 { 返回false; } }
//获取整个文档
foreach (var c in cursor)
{
product prd = new product();
prd.id = check_field(c.ToBsonDocument(), "id") ? convertToString(c.ToBsonDocument()["id"]) : null;
prd.price = check_field(c.ToBsonDocument(), "price") ? JsonConvert.DeserializeObject<price>(c.ToBsonDocument()["price"].ToString()) : null;
products.Add(prd);
}
for (var i = 0; i < products.Count(); i++)
{
price price_list = new price();
price_list.mrp = 500;
MongoDB.Driver.Builders.UpdateBuilder update = MongoDB.Driver.Builders.Update.SetWrapped("price", (price)price_list);
}
当我执行命令时,我希望$ set命令以
的形式发出{ "$set" : { "price" : { "mrp" : 500 }}}
but get this instead
{ "$set" : { "price" : { "mrp" : "599" }}}
任何帮助/指针都非常有帮助
答案 0 :(得分:0)
最后,当我将数据类型更改为double(或float)时,它运行良好。十进制是64位 - 所以mongo将它存储为NumberLong。