C# EF6动态获取表格

C# EF6动态获取表格,c#,reflection,entity-framework-6,C#,Reflection,Entity Framework 6,我首先使用实体框架6和数据库。试图显示关于每个表(DbSet)的信息,包括条目数。 最后,我想显示我的DbContext中任何选定表的一些(前200)行。我试图在没有硬编码特定类型的情况下使用反射来实现这一点 using (MyDataEntities pd = new MyDataEntities()) { var metadata = ((IObjectContextAdapter)pd).ObjectContext.MetadataWorkspace; var table

我首先使用实体框架6和数据库。试图显示关于每个表(
DbSet
)的信息,包括条目数。 最后,我想显示我的
DbContext
中任何选定表的一些(前200)行。我试图在没有硬编码特定类型的情况下使用反射来实现这一点

using (MyDataEntities pd = new MyDataEntities())
{
    var metadata = ((IObjectContextAdapter)pd).ObjectContext.MetadataWorkspace;

    var tables = metadata.GetItemCollection(DataSpace.SSpace)
        .GetItems<EntityContainer>().Single().BaseEntitySets.OfType<EntitySet>()
        .Where(s => !s.MetadataProperties.Contains("Type")
        || s.MetadataProperties["Type"].ToString() == "Tables").ToList();

    // This is working.
    var set = pd.GetType().GetProperty("MyType1").GetValue(pd);
    var theSet = set as DbSet<MyType1>;

    if (theSet != null)
    {
        int count = theSet.Count();     // This is working.
        var rows = theSet.ToList();     // This is working.
    }
          
    foreach (var t in tables)
    {
        dynamic dbset = pd.GetType().GetProperty(t.Name).GetValue(pd);
        int count = dbset.Count();      // This is not working
        var rows = dbset.ToList();      // This is not working
    }
}
使用(MyDataEntities pd=new MyDataEntities())
{
var元数据=((IObjectContextAdapter)pd).ObjectContext.MetadataWorkspace;
var tables=metadata.GetItemCollection(DataSpace.SSpace)
.GetItems().Single().BaseEntitySets.OfType()
.Where(s=>!s.MetadataProperties.Contains(“类型”)
||s.MetadataProperties[“Type”].ToString()=“Tables”).ToList();
//这是有效的。
var set=pd.GetType().GetProperty(“MyType1”).GetValue(pd);
var theSet=设置为DbSet;
如果(theSet!=null)
{
int count=theSet.count();//这正在工作。
var rows=theSet.ToList();//这正在工作。
}
foreach(表中的var t)
{
动态dbset=pd.GetType().GetProperty(t.Name).GetValue(pd);
int count=dbset.count();//这不起作用
var rows=dbset.ToList();//这不起作用
}
}
我得到了一些例外:

Microsoft.CSharp.RuntimeBinder.RuntimeBinderException:''System.Data.Entity.DbSet<MyAppName.MyType1>' does not contain a definition for 'Count''

Microsoft.CSharp.RuntimeBinder.RuntimeBinderException:''System.Data.Entity.DbSet<MyAppName.MyType1>' does not contain a definition for 'ToList''
Microsoft.CSharp.RuntimeBinder.RuntimeBinderException:“System.Data.Entity.DbSet”不包含“Count”的定义
Microsoft.CSharp.RuntimeBinder.RuntimeBinderException:“System.Data.Entity.DbSet”不包含“ToList”的定义

这可能是我正在尝试的吗?

我将动态值转换为IQueryable,然后可以像查询一样使用它

foreach (var t in tables)
{
    dynamic dbset = pd.GetType().GetProperty(t.Name).GetValue(pd);
    var query = dbset as IQueryable;
    var result = query.ToListAsync().Result;
                 

    int count = result.Count();      // This is working
    var rows = result.ToList();      // This is working
}

我将动态值转换为IQueryable,然后可以像查询一样使用它。现在测试代码。作品