时间:2021-07-01 10:21:17 帮助过:2人阅读
打代码已经有好几个月了。
HibernateTemplate hibernateTemplate = getHibernateTemplate();
SessionFactory sessionFactory = hibernateTemplate.getSessionFactory();
Session session = sessionFactory.openSession();
Query query = session.createSQLQuery(hql).addEntity(Arguments.class);
List<Arguments> list = query.list();
if(list.size()>0)
return list;
这一段代码 是使用Hibernate原生态sql. 然后这个方法调用多次之后。会让连接池抽光连接(自己猜想)..----------------如有大神可以回答一下这个问题的根源在哪?
解决办法是 使用
hibernateTemplate.executeFind(new HibernateCallback(){
public Object doInHibernate(org.hibernate.Session session)
throws HibernateException, SQLException {
Query query = session.createSQLQuery(hql).addEntity(Object.class);
List<Object> list = query.list();
return list;
}
使用匿名内部类来代理 就能解决。
为什么呢? 有大神解答一下吗?
hibernate+spring+struts中使用原生态的sql导致oping JDBC connection连接池资源抽光问题
标签: