nhibernate 获取执行过的sql语句(99分)

时间:2021-03-12 04:32:46
大家帮忙,急啊

我们老板要做系统日志,要求是记录用户操作执行的SQL语句,我不知道怎么获取执行过的SQL语句,请大家一定帮忙给个方案啊

软件环境(asp.net+nhibernate+mysql)

8 个解决方案

#1


没用过nhibernate

#2


哪位用过的帮帮忙啊。。。。。。。。

#3


没用过nhibernate,一次听说。
nhibernate 能自动产生SQL语句,太高级了。

我现在也不怎么写SQL语句,只写一个数据类,通过反射和泛型生成SQL语句。
nhibernate 里可能有一个对象专门创建SQL语句,官方文档查查

#4



aspx     
  
 *   
  
 * 使用说明:1. 在Application_Start()中启动定时器(定时清空错误信息):ErrorManager.Instance.Start(),   
  
 *              默认12小时运行一次,或用ErrorManager.Instance.SetTimerInterval()设置。   
  
 *           2. 在Application_Error()中,当发生错误时,保存这个错误信息并转到error.aspx中显示这个错误   
  
 *               string key = ErrorManager.Instance.AddError();   
  
 *               Response.Redirect("error.aspx?key=" + key);   
  
 *           3. 在error.aspx中通过url传来的key,取得并显示错误信息:   
  
 *               string err = ErrorManager.Instance.GetError(key)   
  
 *              err中前19个字符是错误发生的时间,后面是错误信息。   
  
 *           4. 为了捕捉Session超时的错误,而不是返回Session[key]是null的错误信息,本类增加了GetSession()   
  
 *              和SetSession函数来统一管理Session,以后aspx中不能直接读取Session,而必须通过本类来读取。   
  
 *    
  
 *    
  
 * 创建标识:   
  
 *   
  
 * 修改标识:   
  
 * 修改描述:   
  
 *   
  
 * 修改标识:   
  
 * 修改描述:   
  
 *----------------------------------------------------------------*/   
  
using System;   
  
using System.Data;   
  
using System.Configuration;   
  
using System.Web;   
  
using System.Web.Security;   
  
using System.Web.UI;   
  
using System.Web.UI.WebControls;   
  
using System.Web.UI.WebControls.WebParts;   
  
using System.Web.UI.HtmlControls;   
  
using System.Collections;   
  
  
  
/**//// <summary>   
  
/// Summary description for Error   
  
/// </summary>   
  
public class ErrorManager   
  
{   
  
    private System.Timers.Timer m_timer;   
  
    private Hashtable m_htErr;   
  
  
  
    /**//// <summary>   
  
    /// 私有的构造函数   
  
    /// </summary>   
  
    private ErrorManager()   
  
    {   
  
        this.m_timer = new System.Timers.Timer();   
  
        this.m_timer.Enabled = false;   
  
        this.m_timer.Interval = 12 * 60 * 60 * 1000;    //默认12个小时执行一次   
  
        this.m_timer.Elapsed += new System.Timers.ElapsedEventHandler(m_timer_Elapsed);   
  
        this.m_htErr = new Hashtable();   
  
    }   
  
  
  
    /**//// <summary>   
  
    /// 单例模式的接口   
  
    /// </summary>   
  
    public static readonly ErrorManager Instance = new ErrorManager();   
  
  
  
    /**//// <summary>   
  
    /// 设置定时器的频率,单位是毫秒   
  
    /// </summary>   
  
    /// <param name="Interval">毫秒</param>   
  
    public void SetTimerInterval(int Interval)   
  
    {   
  
        this.m_timer.Interval = Interval;   
  
    }   
  
  
  
    /**//// <summary>   
  
    /// 定时器开始   
  
    /// </summary>   
  
    public void TimerStart()   
  
    {   
  
        this.m_timer.Enabled = true;   
  
    }   
  
  
  
    /**//// <summary>   
  
    /// 定时器结束   
  
    /// </summary>   
  
    public void TimerStop()   
  
    {   
  
        this.m_timer.Enabled = false;   
  
    }   
  
  
  
    /**//// <summary>   
  
    /// 发生了一个错误,把错误信息保存起来,并返回错误的id,便于页面中读取   
  
    /// </summary>   
  
    /// <returns>返回错误的id</returns>   
  
    public string AddError()   
  
    {   
  
        string key = Guid.NewGuid().ToString();   
  
        string msg = System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")   
  
            + HttpContext.Current.Server.GetLastError().GetBaseException().Message;   
  
        this.m_htErr.Add(key, msg);   
  
  
  
        HttpContext.Current.Server.ClearError();   
  
  
  
        return key;   
  
    }   
  
  
  
    /**//// <summary>   
  
    /// 返回指定Key的错误信息,前19个字符是错误发生的时间   
  
    /// </summary>   
  
    /// <param name="key">key,是一个guid</param>   
  
    /// <returns>返回错误信息</returns>   
  
    public string GetError(string key)   
  
    {   
  
        return this.m_htErr[key].ToString();   
  
    }   
  
  
  
    /**//// <summary>   
  
    /// 定时在Hashtable中清理错误信息   
  
    /// </summary>   
  
    /// <param name="sender"></param>   
  
    /// <param name="e"></param>   
  
    private void m_timer_Elapsed(object sender, System.Timers.ElapsedEventArgs e)   
  
    {   
  
        ArrayList list = new ArrayList();   
  
        lock (this.m_htErr)   
  
        {   
  
            DateTime now = DateTime.Now;   
  
            TimeSpan ts;   
  
            foreach (string key in this.m_htErr.Keys)   
  
            {   
  
                //前19个字符是错误发生的日期,yyyy-MM-dd HH:mm:ss   
  
                string time = this.m_htErr[key].ToString().Substring(0, 19);       
  
                ts = now - Convert.ToDateTime(time);   
  
                if (ts.TotalMinutes > 20)   //把20分钟前的错误信息从hashtable中清除   
  
                    list.Add(key);   
  
            }   
  
  
  
            foreach (string key in list)   
  
            {   
  
                this.m_htErr.Remove(key);   
  
            }   
  
        }   
  
  
  
    }   


#5


你们老板不懂技术吧
NHibernate是封装了SQL语句没错,封装的目的是什么?
就是让程序员使用Hibernate自带的HQL语句,以面向对象的语法直接查询对象,而不再是查询记录,然后再组装对象

如果真的想记录HQL语句,那可以对hibernate的方法进行再次封装

主要应该就是封装session的get,save,.....query的createQuery(没记错的话)
在里面把HQL语句缓存起来,下次再从缓存中查询就行了

如果要缓存SQL,要么放弃HQL(意味着全部查询都用SqlQuery类来做),或者改写hibernate源代码

也是在那些方法中缓存拼接好的SQL语句

除此之外,暂时想不出别的方法

#6


学习

#7


专业帮顶!

#8


学习

#1


没用过nhibernate

#2


哪位用过的帮帮忙啊。。。。。。。。

#3


没用过nhibernate,一次听说。
nhibernate 能自动产生SQL语句,太高级了。

我现在也不怎么写SQL语句,只写一个数据类,通过反射和泛型生成SQL语句。
nhibernate 里可能有一个对象专门创建SQL语句,官方文档查查

#4



aspx     
  
 *   
  
 * 使用说明:1. 在Application_Start()中启动定时器(定时清空错误信息):ErrorManager.Instance.Start(),   
  
 *              默认12小时运行一次,或用ErrorManager.Instance.SetTimerInterval()设置。   
  
 *           2. 在Application_Error()中,当发生错误时,保存这个错误信息并转到error.aspx中显示这个错误   
  
 *               string key = ErrorManager.Instance.AddError();   
  
 *               Response.Redirect("error.aspx?key=" + key);   
  
 *           3. 在error.aspx中通过url传来的key,取得并显示错误信息:   
  
 *               string err = ErrorManager.Instance.GetError(key)   
  
 *              err中前19个字符是错误发生的时间,后面是错误信息。   
  
 *           4. 为了捕捉Session超时的错误,而不是返回Session[key]是null的错误信息,本类增加了GetSession()   
  
 *              和SetSession函数来统一管理Session,以后aspx中不能直接读取Session,而必须通过本类来读取。   
  
 *    
  
 *    
  
 * 创建标识:   
  
 *   
  
 * 修改标识:   
  
 * 修改描述:   
  
 *   
  
 * 修改标识:   
  
 * 修改描述:   
  
 *----------------------------------------------------------------*/   
  
using System;   
  
using System.Data;   
  
using System.Configuration;   
  
using System.Web;   
  
using System.Web.Security;   
  
using System.Web.UI;   
  
using System.Web.UI.WebControls;   
  
using System.Web.UI.WebControls.WebParts;   
  
using System.Web.UI.HtmlControls;   
  
using System.Collections;   
  
  
  
/**//// <summary>   
  
/// Summary description for Error   
  
/// </summary>   
  
public class ErrorManager   
  
{   
  
    private System.Timers.Timer m_timer;   
  
    private Hashtable m_htErr;   
  
  
  
    /**//// <summary>   
  
    /// 私有的构造函数   
  
    /// </summary>   
  
    private ErrorManager()   
  
    {   
  
        this.m_timer = new System.Timers.Timer();   
  
        this.m_timer.Enabled = false;   
  
        this.m_timer.Interval = 12 * 60 * 60 * 1000;    //默认12个小时执行一次   
  
        this.m_timer.Elapsed += new System.Timers.ElapsedEventHandler(m_timer_Elapsed);   
  
        this.m_htErr = new Hashtable();   
  
    }   
  
  
  
    /**//// <summary>   
  
    /// 单例模式的接口   
  
    /// </summary>   
  
    public static readonly ErrorManager Instance = new ErrorManager();   
  
  
  
    /**//// <summary>   
  
    /// 设置定时器的频率,单位是毫秒   
  
    /// </summary>   
  
    /// <param name="Interval">毫秒</param>   
  
    public void SetTimerInterval(int Interval)   
  
    {   
  
        this.m_timer.Interval = Interval;   
  
    }   
  
  
  
    /**//// <summary>   
  
    /// 定时器开始   
  
    /// </summary>   
  
    public void TimerStart()   
  
    {   
  
        this.m_timer.Enabled = true;   
  
    }   
  
  
  
    /**//// <summary>   
  
    /// 定时器结束   
  
    /// </summary>   
  
    public void TimerStop()   
  
    {   
  
        this.m_timer.Enabled = false;   
  
    }   
  
  
  
    /**//// <summary>   
  
    /// 发生了一个错误,把错误信息保存起来,并返回错误的id,便于页面中读取   
  
    /// </summary>   
  
    /// <returns>返回错误的id</returns>   
  
    public string AddError()   
  
    {   
  
        string key = Guid.NewGuid().ToString();   
  
        string msg = System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")   
  
            + HttpContext.Current.Server.GetLastError().GetBaseException().Message;   
  
        this.m_htErr.Add(key, msg);   
  
  
  
        HttpContext.Current.Server.ClearError();   
  
  
  
        return key;   
  
    }   
  
  
  
    /**//// <summary>   
  
    /// 返回指定Key的错误信息,前19个字符是错误发生的时间   
  
    /// </summary>   
  
    /// <param name="key">key,是一个guid</param>   
  
    /// <returns>返回错误信息</returns>   
  
    public string GetError(string key)   
  
    {   
  
        return this.m_htErr[key].ToString();   
  
    }   
  
  
  
    /**//// <summary>   
  
    /// 定时在Hashtable中清理错误信息   
  
    /// </summary>   
  
    /// <param name="sender"></param>   
  
    /// <param name="e"></param>   
  
    private void m_timer_Elapsed(object sender, System.Timers.ElapsedEventArgs e)   
  
    {   
  
        ArrayList list = new ArrayList();   
  
        lock (this.m_htErr)   
  
        {   
  
            DateTime now = DateTime.Now;   
  
            TimeSpan ts;   
  
            foreach (string key in this.m_htErr.Keys)   
  
            {   
  
                //前19个字符是错误发生的日期,yyyy-MM-dd HH:mm:ss   
  
                string time = this.m_htErr[key].ToString().Substring(0, 19);       
  
                ts = now - Convert.ToDateTime(time);   
  
                if (ts.TotalMinutes > 20)   //把20分钟前的错误信息从hashtable中清除   
  
                    list.Add(key);   
  
            }   
  
  
  
            foreach (string key in list)   
  
            {   
  
                this.m_htErr.Remove(key);   
  
            }   
  
        }   
  
  
  
    }   


#5


你们老板不懂技术吧
NHibernate是封装了SQL语句没错,封装的目的是什么?
就是让程序员使用Hibernate自带的HQL语句,以面向对象的语法直接查询对象,而不再是查询记录,然后再组装对象

如果真的想记录HQL语句,那可以对hibernate的方法进行再次封装

主要应该就是封装session的get,save,.....query的createQuery(没记错的话)
在里面把HQL语句缓存起来,下次再从缓存中查询就行了

如果要缓存SQL,要么放弃HQL(意味着全部查询都用SqlQuery类来做),或者改写hibernate源代码

也是在那些方法中缓存拼接好的SQL语句

除此之外,暂时想不出别的方法

#6


学习

#7


专业帮顶!

#8


学习