查询 mongodb collection 为动态

Query mongodb collection as dynamic

我正在我的数据库中保存 dynamic object,但我还想将其作为动态 object 检索。如何才能做到这一点?我这样试过:

public dynamic GetItemById(ObjectId id)
{
    dynamic result = Db.GetCollection<dynamic>("Items").Find(x => x.Id == id).FirstOrDefaultAsync().Result;
    return result;
}

但这给了我以下错误:

CS1963 An expression tree may not contain a dynamic operation

我知道这可以通过使用类型 object 而不是动态类型来解决。但是我不想使用任何类型化的 objects,因为这违背了使用像 MongoDB(或者至少,恕我直言)这样的 NoSQL 数据库的全部目的。

如何使用 dynamic object 查询 Id 或任何其他 属性 的 collections?

您可以使用基于字符串的语法,因为表达式在 dynamic 中没有任何优势:

var cursor = db.GetCollection<dynamic>("foo").
                Find(Builders<dynamic>.Filter.Eq("_id", someId));