我有一个
Dictionary<string, object>
作为 MongoDB.Save()
的插入输入。
当我用原始类型填充这个字典时 - 序列化过程工作正常,但是当我尝试插入填充一些自定义类(例如 - Person 类)的字典时,我收到下一个错误:
.NET type 'Person' cannot be mapped to a BsonValue
我注意到,如果我插入转换为
BsonDocument
的自定义类型,序列化过程会非常有效。
如何定义 MongoDB 将特定类序列化为
BsonDocument
?
更新:提供真实代码
here is my SensorData class:
[DataContract]
public class SensorData
{
[DataMember]
[BsonElement]
[BsonRepresentation(BsonType.String)]
public string Type { get; set; }
[DataMember]
[BsonElement]
[BsonRepresentation(BsonType.String)]
public string Desc { get; set; }
[DataMember]
[BsonElement]
[BsonRepresentation(BsonType.String)]
public SensorStatus Status { get; set; }
[DataMember]
[BsonElement]
[BsonRepresentation(BsonType.String)]
public string Value { get; set; }
[DataMember]
[BsonElement]
[BsonRepresentation(BsonType.String)]
public string ValueUnits { get; set; }
[DataMember]
[BsonElement]
[BsonRepresentation(BsonType.Boolean)]
public bool Event { get; set; }
[DataMember]
[BsonElement]
[BsonRepresentation(BsonType.Int32)]
public int TTL { get; set; }
}
以下是将数据保存到 MongoDB 的方法:
public void Save(Dictionary<string, object> RawSensorMessageDictionary)
{
try
{
var policyColl = new MongoClient(ConnString).GetServer().GetDatabase(DB_NAME).GetCollection<BsonDocument>(CollectionNames.RawSensorMessage.ToString());
if (!RawSensorMessageDictionary.Any(p => p.Key == "_id")) //if rawSensorMessageID is empty, mongodb will set it
RawSensorMessageDictionary.Add("_id", ObjectId.GenerateNewId().ToString());
var bsonObj = new BsonDocument(RawSensorMessageDictionary);
policyColl.Save(bsonObj);
}
catch (Exception ex)
{
//log exception
}
}
这是我的单元测试的代码:
DataAccess.MongoDAL dal = new DataAccess.MongoDAL();
Dictionary<string, object> dic = new Dictionary<string, object>();
dic.Add("1", true);
dic.Add(Message.RESOURCE_TYPE, "aaa");
dic.Add(Message.RESOURCE_NAME, "bbb");
dic.Add(Message.SENSOR_DATA, new SensorData { Desc = "aaa", Event = true, Status = SensorStatus.Active, TTL = 4, Type = "sss", Value = "222" });
dal.SaveRawSensorData(dic );
我希望我的应用程序自动将
SensorData
对象序列化为 BsonDocument
。如果我不手动执行此操作,则会出现以下异常:.NET type 'SensorData' cannot be mapped to a BsonValue
我该怎么做?
更新2: 好的发现了问题,在我的“保存到数据库”方法中,我使用了下一个代码来转换我的字典
BsonDocument
:
var bsonObj = new BsonDocument(RawSensorMessageDictionary);
我希望从其他对象创建“BsonDocument”的新实例将像
object.ToBsonDocument()
一样处理转换,但显然事实并非如此。
最后我将上面的代码替换为以下代码:
var bsonObj = RawSensorMessageDictionary.ToBsonDocument();
dal.SaveRawSensorData(dic );
现在可以了。
如果字典中的字符串是 mongodb 文档中的属性,那么非基本类型就是 mongodb 中的子文档。请尝试用
[BsonElement]
标记类中的所有属性,并用 [BsonId]
标记 Bson Id。请确保遵循此处的所有规则:使用 C# 驱动程序序列化文档
如果您能提供更多信息就好了
编辑1 除了
Value之外,我会尝试删除
SensorData
的所有属性。如果这有效,我会添加所有其他的(一一)。