首页 > 后端开发 > 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 中不存在。

答案:

EF Core 5/6 / Net 5/ 6

对于带有 .NET 5 和 6 的 EF Core 5 和 6,您可以使用 ToQueryString() 方法:

var query = _context.Widgets.Where(w => w.IsReal && w.Id == 42);
var sql = query.ToQueryString();
登录后复制

对于旧版本的 .NET Core,可以使用扩展方法:

Core 2.1.2

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

    return sql;
}
登录后复制

EF 核心3.0

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 Core 3.1

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 之前的版本到 5,反射对于检索由可查询。

以上是如何查看Entity Framework Core IQueryable生成的SQL?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板