從Entity Framework Core IQueryable 提取SQL 程式碼
在Entity Framework Core 中,取得IQueryable 產生的SQL 程式碼對於偵錯至關重要和性能分析。但是,與先前版本的 Entity Framework 不同,ToTraceString 在 EF Core 中不再可用。
EF Core 5/6
在最新版本的EF Core(5.0 和上方),您可以使用ToQueryString() 來擷取SQL 程式碼方法:
var query = _context.Widgets.Where(w => w.IsReal && w.Id == 42); var sql = query.ToQueryString();
EF Core 2.1.2及更早版本
對於舊版的EF Core(2.1.2 及以下),可以使用以下程式碼取得SQL程式碼:
public static string ToSql<TEntity>(this IQueryable<TEntity> query) { // ... (code omitted for brevity) ... }
注意,此程式碼需要擴充方法定義來存取EF的內部欄位Core。
EF Core 3.0
在EF Core 3.0 中,可以使用以下方法:
public static string ToSql<TEntity>(this IQueryable<TEntity> query) { // ... (code omitted for brevity) ... }
此方法也需要擴充存取內部欄位的方法定義。
EF Core 3.1 和以上
從EF Core 3.1 開始,您可以使用以下方法:
public static string ToSql<TEntity>(this IQueryable<TEntity> query) where TEntity : class { // ... (code omitted for brevity) ... }
此方法使用反射來存取內部欄位並從IQueryable 查詢提供SQL 程式碼。
EF Core 團隊也計劃在未來版本中引入官方取得 SQL 程式碼的方式。
以上是如何從 Entity Framework Core IQueryable 擷取 SQL 程式碼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!