NHibernate输出SQL语句

本文介绍如何在控制台和Web程序中配置NHibernate以输出SQL语句,包括修改配置文件和使用自定义拦截器,便于进行SQL性能调优。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  用了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

posted on 2015-06-09 17:58  逆心 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/kissdodog/p/4564204.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值