时间:2021-07-01 10:21:17 帮助过:17人阅读
在控制台程序中,要查看NHibernate所生成的SQL语句,方法非常简单,只需要改下配置文件就OK了。
- <span style="color: #0000ff;"><</span><span style="color: #800000;">property </span><span style="color: #ff0000;">name</span><span style="color: #0000ff;">="show_sql"</span><span style="color: #0000ff;">></span>true<span style="color: #0000ff;"></</span><span style="color: #800000;">property</span><span style="color: #0000ff;">></span>
- <span style="color: #0000ff;"><</span><span style="color: #800000;">property </span><span style="color: #ff0000;">name</span><span style="color: #0000ff;">="format_sql"</span><span style="color: #0000ff;">></span>true<span style="color: #0000ff;"></</span><span style="color: #800000;">property</span><span style="color: #0000ff;">></span>
第一个参数用于配置是否输出SQL语句到控制台。
第二个参数用于输出的SQL语句是否格式化以便于查看。
只设置第一个与两个都设置的差别如下:
只显示不格式化:
格式化后:
上面的方法是配置控制台显示的,如果不在控制台里执行,是Web程序呢。
Web程序输出的方式也不难。
第一步:写一个类,继承自EmptyInterceptor并重写OnPrepareStatement方法。
- <span style="color: #0000ff;">public</span> <span style="color: #0000ff;">class</span><span style="color: #000000;"> SQLWatcher : EmptyInterceptor
- {
- </span><span style="color: #0000ff;">public</span> <span style="color: #0000ff;">override</span><span style="color: #000000;"> NHibernate.SqlCommand.SqlString OnPrepareStatement(NHibernate.SqlCommand.SqlString sql)
- {
- System.Diagnostics.Debug.WriteLine(</span><span style="color: #800000;">"</span><span style="color: #800000;">sql语句:</span><span style="color: #800000;">"</span> +<span style="color: #000000;"> sql);
- </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">base</span><span style="color: #000000;">.OnPrepareStatement(sql);
- }
- }</span>
第二步:在创建OpenSession的时候,用此类的对象作为参数传入
- ISession session = sessionFactory.OpenSession(<span style="color: #0000ff;">new</span> SQLWatcher());
效果如下:
参考:http://www.mashangpiao.net/Article/Content/53
NHibernate输出SQL语句
标签: