Spring + Hibernate 数据访问策略
2007-09-26 23:13
337 查看
都说Spring 和 Hibernate是绝配。今天有点小小心得,拿出来共享一下。
当我们费了九牛二虎之力终于把环境全配好之后,有一个问题摆在面前:
如何访问数据库?
通过继承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。这样也可以,就是麻烦点。
参见:
http://springframework.org/docs/api/org/springframework/orm/hibernate3/HibernateTemplate.html
http://www.mxjava.com/blog/article.asp?id=246
请各位高手不吝赐教。
另:用myEclipse自动生成的HibernateDAO代码中。4.1.1版本的myEclipse自动生成的findById方法使用的是getSession方法获得连接,不过在6.0中已经修改为使用getHibernateTemplate方法。5.0的没有测试。
当我们费了九牛二虎之力终于把环境全配好之后,有一个问题摆在面前:
如何访问数据库?
通过继承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。这样也可以,就是麻烦点。
参见:
http://springframework.org/docs/api/org/springframework/orm/hibernate3/HibernateTemplate.html
http://www.mxjava.com/blog/article.asp?id=246
请各位高手不吝赐教。
另:用myEclipse自动生成的HibernateDAO代码中。4.1.1版本的myEclipse自动生成的findById方法使用的是getSession方法获得连接,不过在6.0中已经修改为使用getHibernateTemplate方法。5.0的没有测试。
相关文章推荐
- Spring + Hibernate 数据访问策略
- Struts 2 + Hibernate + Spring 开发环境的搭建与数据访问Dao的生成
- 【Spring 数据访问终篇】Spring + Hibernate + Mysql
- Spring 数据访问策略
- Spring ORM数据访问——Hibernate
- JPA hibernate spring repository pgsql java 工程(三):数据表分区与自动创建:策略
- Spring数据访问策略_使用JdbcTemplate
- 关于Spring的数据访问---Hibernate
- Hibernate和Spring整合中数据查询hql与Criteria Query
- SpringBoot 之数据访问
- Hibernate中的数据的获取策略(fetching)
- 采用C3P0连接池解决spring+hibernate+mysql 访问空闲8小时后自动断开连接的问题
- struts+spring+hibernate无法插入数据库数据的问题
- Spring Boot中使用Spring-data-jpa让数据访问更简单、更优雅
- Spring、Hibernate 数据不能插入到数据库问题解决
- Spring boot 参数拼在访问路径中,如果参数带 点(符合)后面数据取不到
- Spring Boot与Spring Security整合后post数据不了,403拒绝访问
- 转:Spring 资源访问剖析和策略模式应用
- Spring2.5 访问 Session 属性的四种策略
- 5.1 Spring的数据访问哲学