zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    SDOI2011古代朱文
    LIS 堆优化
    ZR2019 广州 游记
    LG2709 小B的询问
    [SCOI2009] 生日礼物
    [SDOI2008]沙拉公主的困惑
    [LG3396]哈希冲突
    ZROI2018.8.2 菜鸡互啄杯组队 ACM 赛
    ZROI 菜鸡互啄杯 III
    [LG4016] 负载平衡问题
  • 原文地址:https://www.cnblogs.com/ROOKIEDEBUG/p/9287779.html
Copyright © 2011-2022 走看看