如何循环访问泛型中的所有 DbSet



(我在这里使用 EF6)假设我有一个抽象类:

public abstract class MyContext<T> : DbContext

让我们使用它:

public class MyTestContext : MyContext<MyTestContext>
{
    public DbSet<Object1> Object1 { get; set; }
    public DbSet<Object2> Object2 { get; set; }
}

现在,假设我想在我的抽象类中迭代 MyTestContext 中的所有 DbSets。 似乎这会起作用(这是我抽象类的方法):

var dbSetProperties = typeof(T).GetProperties().Where(p => p.PropertyType == typeof(DbSet<>));

然而,我得到"枚举没有产生任何结果"。

我在这里做错了什么? 谢谢!

编辑 注意 - 我不希望预先知道泛型类型参数 - 我实际上希望确定每个 DbSet 中的类型。

所以Foo<T>不是Foo<>型。您需要获取Foo<T>的泛型类型定义并进行比较。

var dbSetProperties = typeof(MyTestContext)
    .GetProperties()
    .Where(p => p.PropertyType.GetGenericTypeDefinition() == typeof(DbSet<>));

最新更新