国产探花免费观看_亚洲丰满少妇自慰呻吟_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://m.survivalescaperooms.com/caoming/p/4147600.html


發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 常宁市| 绿春县| 常山县| 永新县| 池州市| 石阡县| 靖宇县| 兴义市| 嵩明县| 丹东市| 福安市| 增城市| 上饶市| 巴彦县| 辽阳县| 西吉县| 中方县| 隆尧县| 虎林市| 郴州市| 长岭县| 株洲市| 台北县| 淳安县| 巴南区| 贵德县| 盱眙县| 商河县| 昆山市| 河北区| 泗洪县| 景泰县| 出国| 南投市| 开阳县| 舒城县| 崇仁县| 建瓯市| 修武县| 沂水县| 济阳县|