国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

[NHibernate]查看NHibernate生成的SQL語句

2019-11-17 01:54:34
字體:
供稿:網(wǎng)友

[NHibernate]查看NHibernate生成的SQL語句

最近接觸到一個用SPRing.Net結(jié)合NHIbernate的項(xiàng)目,第一次使用,有很多配置,數(shù)據(jù)操作一旦出問題,很難找到原因,那么如何查看NHibernate發(fā)送給數(shù)據(jù)庫的SQL語句呢?

當(dāng)然我們可以通過log4net記錄日志來查看,但稍微有些繁瑣,于是找到了另一種方法來查看。

NHIbernate中的IInterceptor接口中定義的OnPrepareStatement(SqlString sql)可以觀察到生成的sql,由EmptyInterceptor來實(shí)現(xiàn)。

[Serializable]public class EmptyInterceptor : IInterceptor{       //其他方法省略      public virtual SqlString OnPrepareStatement(SqlString sql);}

我們所要做的就是繼承EmptyInterceptor,然后重寫OnPrepareStatement方法。

public class SQLWatcher : EmptyInterceptor{    public override SqlCommand.SqlString OnPrepareStatement(SqlCommand.SqlString sql)    {        return base.OnPrepareStatement(sql);    }}

在重寫的方法里,你就可以用任何方法來監(jiān)控你的所想要監(jiān)控的SQL語句了。

最后在創(chuàng)建Isession的地方加入你所創(chuàng)建的攔截類就可以了。

public static ISession OpenSession(){     return SessionFactory.OpenSession(new SQLWatcher());}

運(yùn)行效果如下:

轉(zhuǎn)載請注明來源:http://www.survivalescaperooms.com/caoming/p/4147600.html


發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 顺昌县| 乐安县| 常山县| 顺昌县| 新兴县| 疏附县| 福贡县| 泌阳县| 福海县| 共和县| 介休市| 邓州市| 治县。| 泽普县| 开阳县| 洛浦县| 剑河县| 宣恩县| 长子县| 贺兰县| 阳新县| 平定县| 慈溪市| 清远市| 金昌市| 昌乐县| 淅川县| 广东省| 清丰县| 增城市| 太湖县| 永寿县| 澎湖县| 石棉县| 黔南| 阿拉善右旗| 河津市| 高台县| 若羌县| 河间市| 磴口县|