Ich suche nach einem Äquivalent von DataContext.GetTable<TEntity>
in Entity Framework.
Ich habe die ObjectContext.CreateQuery<T>
-Methode gefunden, aber sie unterscheidet sich von DataContext.GetTable<TEntity>
, da sie eine Querystring benötigt, um zu funktionieren.
Gibt es eine Möglichkeit, ein IQueryable-Objekt für eine Tabelle mit dem Entitätstyp ohne Angabe der Querystring zu erhalten?
*EDIT: Added code snippet*
Dies ist ein Ausschnitt einer Repository-Klasse, die ich implementiert habe und die mit linq2sql funktioniert. Ich kann ObjectContext.[TableName]
nicht verwenden, weil es nicht mehr generisch wäre.
*EDIT: Added my solution (so far..)*
Das ist was ich benutze:
Dies funktioniert, solange der Klassenname dem Tabellennamen entspricht. Dies wird ein Problem für mich, wenn ich anfangen werde, verschiedene Objekte für die gleiche Tabelle zu verwenden.
Ich hoffe, ich war klar, danke im voraus,
Marco:)
Tatsächlich verwendet der EF-Designer selbst CreateQuery
mit fest codierten Strings für die statischen Referenzen. Wenn Sie in die Designer-Datei schauen, sehen Sie etwa Folgendes:
Technisch gibt es keine perfekte Lösung, da Sie denselben Entitätstyp für verschiedene Entitätsgruppen verwenden können. Aber Sie können es den alten College-Versuch geben:
%Vor%Tags und Links .net c# entity-framework