将MongoDB文档序列化为POCO时,是否有任何方法可以使属性映射不区分大小写?例如,我想要这份文件:
{
"id": "1"
"foo": "bar"
}
映射到此类:
public MyObj
{
public int Id {get; set;}
public string Foo {get; set;}
}
答案 0 :(得分:4)
要做到这一点,我认为你将有2个选择。
首先是手动写出一个类地图
BsonClassMap.RegisterClassMap<MyClass>(cm => {
cm.AutoMap();
cm.GetMemberMap(c => c.Foo).SetElementName("foo");
});
第二种方法是用以下属性装饰你的类
public class MyObj
{
[BsonElement("id")]
public int Id { get; set; }
[BsonElement("foo")]
public string Foo { get; set; }
}
CSharp驱动程序团队在以下链接上有一个关于序列化的好教程
http://docs.mongodb.org/ecosystem/tutorial/serialize-documents-with-the-csharp-driver/
我刚刚尝试了以下内容,这对我有用,显然我确定这是一个更加简化的代码版本,但会猜测它的外观。
我已经分别注册了两个类映射,并将BsonKnownType添加到基类。
[BsonKnownTypes(typeof(GeoJSONObject))]
public class Point
{
public string Coordinates { get; set; }
}
public class GeoJSONObject : Point
{
public string Type { get; set; }
}
static void Main(string[] args)
{
var cn = new MongoConnectionStringBuilder("server=localhost;database=MyTestDB;");
var settings = MongoClientSettings.FromConnectionStringBuilder(cn);
var client = new MongoClient(settings);
BsonClassMap.RegisterClassMap<Point>(cm =>
{
cm.AutoMap();
cm.GetMemberMap(c => c.Coordinates).SetElementName("coordinates");
});
BsonClassMap.RegisterClassMap<GeoJSONObject>(cm =>
{
cm.AutoMap();
cm.GetMemberMap(c => c.Type).SetElementName("type");
});
var result = client.GetServer()
.GetDatabase("MyTestDB")
.GetCollection("MyCol")
.Find(Query.EQ("type", BsonValue.Create("xxxx")));
}