Ekstrak Kod SQL daripada Entiti Framework Core IQueryable
Dalam Entiti Framework Core, mendapatkan kod SQL yang dijana oleh pertanyaan IQueryable adalah penting untuk penyahpepijatan dan analisis prestasi. Walau bagaimanapun, tidak seperti versi sebelumnya bagi Rangka Kerja Entiti, ToTraceString tidak lagi tersedia dalam EF Core.
EF Core 5/6
Dalam versi terbaru EF Core (5.0 dan di atas), anda boleh mendapatkan semula kod SQL menggunakan ToQueryString() kaedah:
var query = _context.Widgets.Where(w => w.IsReal && w.Id == 42); var sql = query.ToQueryString();
EF Core 2.1.2 dan Lebih Lama
Untuk versi lama EF Core (2.1.2 dan ke bawah), anda boleh menggunakan kod berikut untuk mendapatkan kod SQL:
public static string ToSql<TEntity>(this IQueryable<TEntity> query) { // ... (code omitted for brevity) ... }
Perhatikan bahawa kod ini memerlukan definisi kaedah sambungan untuk mengakses medan dalaman EF Teras.
EF Core 3.0
Dalam EF Core 3.0, anda boleh menggunakan kaedah berikut:
public static string ToSql<TEntity>(this IQueryable<TEntity> query) { // ... (code omitted for brevity) ... }
Kaedah ini juga memerlukan sambungan takrifan kaedah untuk mengakses medan dalaman.
EF Core 3.1 dan Di atas
Bermula dari EF Core 3.1, anda boleh menggunakan kaedah berikut:
public static string ToSql<TEntity>(this IQueryable<TEntity> query) where TEntity : class { // ... (code omitted for brevity) ... }
Kaedah ini menggunakan refleksi untuk mengakses medan dalaman dan menyediakan kod SQL daripada pertanyaan IQueryable.
Pasukan Teras EF juga merancang untuk memperkenalkan cara rasmi untuk mendapatkan kod SQL dalam keluaran akan datang.
Atas ialah kandungan terperinci Bagaimana untuk Mengekstrak Kod SQL daripada Rangka Kerja Entiti Teras IQueryable?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!