c# – 将mongodb集合查询为动态
发布时间:2020-12-15 23:25:09 所属栏目:百科 来源:网络整理
导读:我正在我的数据库中保存一个动态对象,但我也想将其作为动态对象检索.如何才能做到这一点?我试过这样: public dynamic GetItemById(ObjectId id){ dynamic result = Db.GetCollectiondynamic("Items").Find(x = x.Id == id).FirstOrDefaultAsync().Result;
我正在我的数据库中保存一个动态对象,但我也想将其作为动态对象检索.如何才能做到这一点?我试过这样:
public dynamic GetItemById(ObjectId id) { dynamic result = Db.GetCollection<dynamic>("Items").Find(x => x.Id == id).FirstOrDefaultAsync().Result; return result; } 但这给了我以下错误:
我知道这可以通过使用类型化对象而不是动态对象来修复.但我不想使用任何类型的对象,因为这种方式违背了使用像MongoDB(或至少是imho)这样的NoSQL数据库的全部目的. 如何使用动态对象通过Id或任何其他属性查询我的集合? 解决方法
您可以使用基于字符串的语法,因为表达式无论如何都不会提供动态的任何优势:
var cursor = db.GetCollection<dynamic>("foo"). Find(Builders<dynamic>.Filter.Eq("_id",someId)); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |