如何查看 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中文网其他相关文章!