MongoDB C# 2.x驱动程序中的ElemMatch与字典

3

我正在尝试使用ElemMatch在MongoDB中查找文档,但是使用2.2驱动程序没有成功。 我收到了如下异常:

System.InvalidOperationException:字段“EnabledForProduct”的序列化器必须实现IBsonArraySerializer并提供项序列化信息。

这是我的类的样子:

public class Document
{
  public string Id {get; set;}
  public Dictionary<Product, bool> EnabledForProduct { get; set; }
}
public enum Product {Product1,Product2};

我的ClassMap如下:

BsonClassMap.RegisterClassMap<Document>(cm =>
{
    cm.AutoMap();
    cm.MapMember(c => c.EnabledForProduct)
      .SetSerializer(new DictionaryInterfaceImplementerSerializer<Dictionary<Product, bool>>(DictionaryRepresentation.ArrayOfDocuments, 
                        BsonSerializer.LookupSerializer<int>(), 
                        BsonSerializer.LookupSerializer<bool>()));
});

异常情况发生在尝试使用过滤器(Filter)时,例如:
Builders<Document>.Filter.ElemMatch(f => f.EnabledForProduct,
    x => x.Key == Product1 && x.Value))

在1.x驱动程序中,这个功能曾经完美运行。

有人知道我做错了什么吗?

1个回答

3

经过一些尝试和实现,我找到了一个解决办法。我没有直接使用我的模型类,而是使用了一个仅用于ElemMatch过滤器的BsonDocument集合,就像这样:

var bsonCollection = database.GetCollection<BsonDocument>("testcollection");

过滤器的创建方式如下:
var filter = Builders<BsonDocument>.Filter.ElemMatch("EnabledForProduct", Builders<BsonDocument>.Filter.And(Builders<BsonDocument>.Filter.Eq("k",(int)Product.Product1),Builders<BsonDocument>.Filter.Eq("v",true)));

使用BsonSerializer,可以将通用的BsonDocument反序列化回我的模型类:

var foundDoc = BsonSerializer.Deserialize<Document>(bsonCollection.Find(filter).Limit(1).FirstOrDefault());

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接