Console程序下監控EFCore生成的SQL語句!


  最近這兩天在使用控制台程序學習EFCore,突然想看看生成的SQL語句,所以在網上找到一位大神的分享的方法!

  准備工作:

  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包保持版本號一致)

  代碼和結果:

  

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語句。

  ToUnevaluated()這個方法可以返回翻譯Linq語句失敗的Sql語句。

 

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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM