26

LINQ to SQLでは、を使用して動的にリポジトリを作成できますDataContext.GetTable<T>。特定のプロパティを宣言する以外に、Entity Framework 4でこれを行う同様の方法はありDbContextますか?例えば:

public MyDbContext: DbContext
{
    public DbSet<MySet> MySets {get; set;}
}

MySetsLINQ to SQLを使用して、次のように動的に参照を作成/取得する方法を知りたいです。

var mySet = MyDbContext.GetTable<MySet>();
4

3 に答える 3

44

DbContextこのための方法があります:

  var set = context.Set<MyEntity>();
于 2011-03-15T08:54:07.183 に答える
20

使用する:

DbSet<MyEntity> set = context.Set<MyEntity>();

または、一般的な方法を使用できない場合:

DbSet set = context.Set(
    typeof( MyEntity )
);

POCOの2回目の読み込みと複製について心配する必要はありません。セットは、コンテキストによって内部的にキャッシュされます。

于 2011-03-15T09:48:12.663 に答える
2

これが私のアプローチです:

    public static List<T> GetCollection<T>()
    {
        List<T> lstDynamic = null;

        using (MyDbContext db = new MyDbContext())
        {
            DbSet mySet = db.Set(typeof(T));
            mySet.Load();
            var list = mySet.Local.Cast<T>();

            lstDynamic = list.ToList();
        }
        return lstDynamic;
     }

そして、この関数を次のように呼び出します。

List<Customer> lst = StaticClass.GetCollection<Customer>();

これにより、コレクション全体が返されます。これを使用して、コンテンツをあまり変更しない基本的なテーブルのキャッシュ機能を実行しました。

于 2020-03-13T18:55:42.077 に答える