将mongodb集合查询为动态

时间:2015-05-24 09:10:47

标签: c# mongodb dynamic

我在我的数据库中保存了一个dynamic对象,但我还希望将其作为动态对象进行检索。如何才能做到这一点?我试过这样:

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

但是这给了我以下错误:

  

CS1963表达式树可能不包含动态操作

我知道这可以通过使用类型化对象而不是动态对象来解决。但是我不想使用任何类型的对象,因为这样会破坏使用像MongoDB(或至少是imho)这样的NoSQL数据库的整个目的。

如何使用Id对象dynamic或任何其他属性查询我的馆藏?

1 个答案:

答案 0 :(得分:7)

您可以使用基于字符串的语法,因为表达式无论如何都不会带来dynamic的任何优势:

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