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语句是否格式化以便于查看。
只设置第一个与两个都设置的差别如下:
只显示不格式化:
格式化后:
上面的方法是配置控制台显示的,如果不在控制台里执行,是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());
效果如下:
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。