将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
对象的任何其他属性来查询我的集合?
您可以使用基于字符串的语法,因为表达式无论如何都不会为dynamic
提供任何优势:
var cursor = db.GetCollection<dynamic>("foo").
Find(Builders<dynamic>.Filter.Eq("_id", someId));