首頁 > 後端開發 > C++ > 如何查看Entity Framework Core IQueryable產生的SQL?

如何查看Entity Framework Core IQueryable產生的SQL?

Barbara Streisand
發布: 2025-01-03 06:15:39
原創
214 人瀏覽過

How Do I View the SQL Generated by Entity Framework Core IQueryable?

如何查看Entity Framework Core IQueryable 產生的SQL

問題:

問題:

問題:

在Entity 中Framework Core,如何存取IQueryable 物件產生的SQL 程式碼?先前版本中提供的 ToTraceString() 方法在 EF Core 中不存在。

答案:

var query = _context.Widgets.Where(w => w.IsReal && w.Id == 42);
var sql = query.ToQueryString();
登入後複製

EF Core 5/6 / Net 5/ 6

對於帶有.NET 5 和6的EF Core 5 和6,您可以使用ToQueryString()方法:

public static string ToSql<TEntity>(this IQueryable<TEntity> query)
{
    // Reflection and casting voodoo to get EF internal classes
    var sql = ...;

    return sql;
}
登入後複製
對於舊版的.NET Core,可以使用擴充方法:

Core 2.1.2

public static string ToSql<TEntity>(this IQueryable<TEntity> query)
{
    using (var enumerator = query.Provider.Execute<IEnumerable<TEntity>>(query.Expression).GetEnumerator())
    {
        // More reflection and casting voodoo
        var sql = ...;

        return sql;
    }
}
登入後複製

EF核心3.0

public static string ToSql<TEntity>(this IQueryable<TEntity> query) where TEntity : class
{
    using (var enumerator = query.Provider.Execute<IEnumerable<TEntity>>(query.Expression).GetEnumerator())
    {
        // Even more reflection and casting voodoo
        var sql = ...;

        return sql;
    }
}
登入後複製

EF Core 3.1

注意:注意:注意:

以上是如何查看Entity Framework Core IQueryable產生的SQL?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板