最近這兩天在使用控制檯程序學習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