Console程序下监控EFCore生成的SQL语句!

  最近这两天在使用控制台程序学习EFCore,忽然想看看生成的SQL语句,因此在网上找到一位大神的分享的方法!sql

  准备工做:post

  1). MySqlEFCore NuGet:   Pomelo.EntityFrameworkCore.MySql     (要2.0.0版本或与下面的NuGet包版本一致)学习

     2). 查看sql语句的扩展包: Pomelo.EntityFrameworkCore.Extensions.ToSql -Version 2.0.0-rtm-10002  (建议使用install-package命令进行安装,该NuGet包目前最新是2.0.0版本,要和上面个的MySqlEFCore包保持版本号一致)lua

  代码和结果:spa

  

var temp = ctx.Students.Join(ctx.Classes, s => s.ClassId, c => c.Id, (s, c) => new
                {
                    sName = s.Name,
                    cName = c.Name
                });
                Console.WriteLine(temp.ToSql());

                foreach(var t in temp)
                {
                    Console.WriteLine($"{t.sName}:{t.cName}");
                }

  

 从上面的代码看出:Console.WriteLine(temp.ToSql()); 中的ToSql()是转换sql语句的重要方法。转到ToSql定义:翻译

 

  ToSql()是一个参数为IQueryable的扩展方法,返回的string类型的结果,就表明着执行的SQL语句。3d

  ToUnevaluated()这个方法能够返回翻译Linq语句失败的Sql语句。blog

 

    原文地址:http://www.1234.sh/post/to-sql-ef-core-addonsstring

相关文章
相关标签/搜索