使用实体框架按名称获取表

时间:2019-11-25 11:36:24

标签: c# entity-framework

我有这段代码,一切正常。

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 NameEntity Framework get table by variable name,但是没有任何运气。 能做到吗?

1 个答案:

答案 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();

参考:How do I use reflection to call a generic method?