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 自动变成数字引起出错的主要内容,如果未能解决你的问题,请参考以下文章