getSession().createQuery__getHibernateTemplate().find
来源:互联网 发布:软件业务销售合同范本 编辑:程序博客网 时间:2024/06/03 16:34
getSession()是会自动释放连接的。但是在一个线程内getSession会get很多个session(就是开很多个会话、连接),很可能导致数据库连接超过上限。所以推荐使用getHibernateTemplate。”
通过继承HibernateDaoSupport我们有两个选择:getSession().createQuery("from Users");getHibernateTemplate().find( "FROM Users);用哪个呢?困惑啊。网上找了找资料都是推荐用getHibernateTemplate,原因说的不是很清楚。于是我做了如下测试:分别循环调用getSession().createQuery("from Users");getHibernateTemplate().find( "FROM Users);1000次结果getSession()很快就包无法建立连接了。而getHibernateTemplate屁事没有可以跑完。通过后台观察,使用getSession会在数据库中留下很多SQL*Net message from client的连接,终止测试后连接自动释放。而getHibernateTemplate则从头到尾都使用一个连接。难道是getSession()不会自动释放连接?于是我又分别循环调用getSession().createQuery("from Users");getHibernateTemplate().find( "FROM Users);5次发现当前端程序一结束,getSession的5个连接立刻就释放了。结合前面1000次时终止测试后连接自动释放,可以说明getSession()是会自动释放连接的。结论:1、getSession()和getHibernateTemplate都可以自动释放连接(当然你的配置要正确),但是在一个线程内getSession会get很多个session(就是开很多个会话、连接),很可能导致数据库连接超过上限。所以推荐使用getHibernateTemplate。2、如果有些语句无法用getHibernateTemplate实现,可以使用getHibernateTemplate.execute使用HibernateCallback回调接口。另:可以设定HibernateTemplate的AllowCreate为True,并在finally中关闭Session。也可以将true作为参数传递到super.getSession(..)方法中取得Session。这样也可以,就是麻烦点。另外:getSession() 获得的是原始的sessionFactory,每次你必须自己维护session如结束后你必须关闭session。如果是hibernate中进行数据库操作,你获得是原始的hibernate style和excepttion。而hibernate template是spring包装过的,它会帮你管理session,并且它会将hibernate exceptions转换成其他的分类后的错误。这点getSession是肯定不行了。例如你用orcle和mysql返回的错误在getSession中就是不一样的,而在hibernate template中就是一样的。 但我在实际使用中发现,对于基本的操作Hibernate template处理的的确比getSession要好,但到了复杂查询的时候如分页时需要调用getHibernateTemplate().execute(HibernateCallBack).要产生很多innerClass,调试非常不便。而getSession就相当简单多了。
阅读全文
0 0
- getSession().createQuery__getHibernateTemplate().find
- getSession()
- getSession()
- getSession().createQuery("from Users");与getHibernateTemplate().find( "FROM Users);
- getSession() , getSession(false) ,getSession(true) 区别
- getSession().getParameter();getSession( ).getAttribute;getSession().removeAttribute()讲解
- request.getSession()
- request.getSession()
- request.getSession()
- request.getSession()
- request.getSession
- request.getSession()&request.getSession(boolean)
- java session.getSession(),session.getSession(true),session.getSession(false);
- request.getSession(true) request.getSession(false) request.getSession()
- request getsession() getsession(boolean create) invalidate() 说明
- getSession(true)和getSession(),有什么区别
- request.getSession()与getSession(boolean isNew)
- getSession(true)和getSession(),有什么区别
- Linux系统的定时及延时执行任务
- AIDL使用注意
- 242. Valid Anagram
- 网络控制工具类
- cJSON实例
- getSession().createQuery__getHibernateTemplate().find
- Linux图像界面与文本模式的简单切换方法
- C++ 解析Json——jsoncpp
- ZZULIOJ 【1036】 某年某月有多少天【水题】
- memset 赋值
- Windows下Sqlmap的使用
- U
- 全排列以及字典序
- 日志工具类:Log