查询 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));
我正在我的数据库中保存 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));