MongoDB c#驱动程序SetWrapped问题

时间:2013-09-24 17:15:53

标签: c# mongodb

**更新了更多代码:

我有一个类似于

的类/实体
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" }}}

任何帮助/指针都非常有帮助

1 个答案:

答案 0 :(得分:0)

最后,当我将数据类型更改为double(或float)时,它运行良好。十进制是64位 - 所以mongo将它存储为NumberLong。