zoukankan      html  css  js  c++  java
  • NHibernate输出SQL语句

      用了NHierbate之后,很少需要写原生的SQL语句,由于总是看不到SQL语句,所以有时候对SQL调优非常不利。因此产生了让NHibernate输出它所生成的SQL语句的想法,以便于后续调优。

    一、在控制台输出SQL语句

      在控制台程序中,要查看NHibernate所生成的SQL语句,方法非常简单,只需要改下配置文件就OK了。

    <property name="show_sql">true</property>
    <property name="format_sql">true</property>

      第一个参数用于配置是否输出SQL语句到控制台。

      第二个参数用于输出的SQL语句是否格式化以便于查看。

      只设置第一个与两个都设置的差别如下:

      只显示不格式化:

    1.png

      格式化后:

    2.png

      上面的方法是配置控制台显示的,如果不在控制台里执行,是Web程序呢。

    二、Web程序输出SQL语句到“调试窗口”

      Web程序输出的方式也不难。

      第一步:写一个类,继承自EmptyInterceptor并重写OnPrepareStatement方法。

    public class SQLWatcher : EmptyInterceptor
    {
        public override NHibernate.SqlCommand.SqlString OnPrepareStatement(NHibernate.SqlCommand.SqlString sql)
        {
            System.Diagnostics.Debug.WriteLine("sql语句:" + sql);
            return base.OnPrepareStatement(sql);
        }
    }

      第二步:在创建OpenSession的时候,用此类的对象作为参数传入

    ISession session = sessionFactory.OpenSession(new SQLWatcher());

      效果如下:

      3.png

      参考:http://www.mashangpiao.net/Article/Content/53

  • 相关阅读:
    bzoj4554: [Tjoi2016&Heoi2016]游戏
    bzoj3166: [Heoi2013]Alo
    luogu3398 仓鼠找sugar
    bzoj3261: 最大异或和
    bzoj3446: [Usaco2014 Feb]Cow Decathlon
    BZOJ1742[Usaco2005 nov]Grazing on the Run 边跑边吃草
    bzoj2750: [HAOI2012]Road
    bzoj4448: [Scoi2015]情报传递
    bzoj2809: [Apio2012]dispatching
    bzoj 1452
  • 原文地址:https://www.cnblogs.com/kissdodog/p/4564204.html
Copyright © 2011-2022 走看看