我有这段代码,一切正常。
using (var db = new ApplicationDbContext())
{
md = db.Modles.ToList();
}
我的问题是我有一个名为M
的参数,这是我创建的模型的名称,因此它可以是动态的。
有没有办法做这样的事情:
var M = "Modles"; // or M = "Modles2"
using (var db = new ApplicationDbContext())
{
md = db[M].ToList();
}
我尝试过Entity Framework Get Table By Name和Entity Framework get table by variable name,但是没有任何运气。 能做到吗?
答案 0 :(得分:0)
您提供的第二个链接的解决方案实际上不起作用,因为它缺少一个简单的步骤:Set
上的方法DbContext
是通用方法,因此您不能在不告知类型的情况下简单地调用它,无论是在编译时还是至少在运行时。由于希望动态调用它,因此可以选择运行时解析。以下示例应该起作用:
var entityNs = "myentities";
var table = "Model";
var entityType = Type.GetType($"{entityNs}.{table}");
var methodInfo = typeof(ApplicationDbContext).GetMethod("Set");
var generic = methodInfo.MakeGenericMethod(entityType);
dynamic dbSet = generic.Invoke(myContext, null);
var list = dbSet.GetList();