当前位置:Gxlcms > 数据库问题 > hibernate+spring+struts中使用原生态的sql导致oping JDBC connection连接池资源抽光问题

hibernate+spring+struts中使用原生态的sql导致oping JDBC connection连接池资源抽光问题

时间: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连接池资源抽光问题

标签:

人气教程排行