将mongodb的collection查询为动态

本文关键字:动态 查询 collection mongodb | 更新日期: 2023-09-27 17:50:30

我在我的数据库中保存一个dynamic对象,但我也想检索它作为一个动态对象。如何做到这一点?我试了一下:

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

但是这给了我以下错误:

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

我知道这可以通过使用类型化对象而不是动态对象来修复。但是我不想使用任何类型的对象,因为这有点违背了使用像MongoDB这样的NoSQL数据库的整个目的(或者至少,imho)。

我如何通过Id或使用dynamic对象的任何其他属性来查询我的集合?

将mongodb的collection查询为动态

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

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