Mongo中,数组中的string 自动变成数字引起出错

Posted 布里渊区

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mongo中,数组中的string 自动变成数字引起出错相关的知识,希望对你有一定的参考价值。

遇到的问题:

有个Message对象,其中有个字段 叫  UseridList ,类型为 List<string> ,将Message对象序列化后,存入Mongo

var message=new Message(){  UserList=new List<string>(){"02222222222222222222222"} }; 

var bd = BsonDocument.Parse(JsonConvert.SerializeObject(message));

Task t
= collection.InsertOneAsync(bd);
然后将Message读出来
var UseridList = JsonConvert.DeserializeObject<List<string>>(item.GetElement("UseridList").Value.ToString())

在这一句代码出错!!!!错误提示是:input string "02222222222222222222222" is not a valid number 

感觉有点莫名其妙,明明转换成string,怎么会有这个提示?

反复调试发现,item.GetElement("UseridList").Value 读出来是mongo 类型的数组,原本的字符串数组,直接变成了数字数组。所以外层再进行json转换时会出错!

那么,可以换一种写法,下面就正确了:

UseridList=JsonConvert.DeserializeObject<List<string>>(item.GetValue("UseridList").ToJson()),

 

以上是关于Mongo中,数组中的string 自动变成数字引起出错的主要内容,如果未能解决你的问题,请参考以下文章

在 mongo 和 upsert 中更新数组

防止插入Mongo集合的数组中的空值

命名键与数字键 - mongo

Java中字符串按逗号分开成为String数组

通过 mongoose 将项目推送到 mongo 数组中

通过 mongoose 将项目推送到 mongo 数组中