Hibernate 自定义查询卡死情况解决

    我们使用hibernate查询的时候经常会遇到多查询几次卡死的问题,其实这里主要是session不够用了,当每查询一次时就会创建一个session 如下面的一个简单分页查询

public List findPageService(int pageNow,int pageSize)
{ 
String hql="。。。。。。。。。。。。。";
Session session=getHibernateTemplate().getSessionFactory().openSession();
Query q= session.createQuery(hql);
int first=(pageNow-1)*pageSize;
q.setFirstResult(first);
q.setMaxResults(pageSize);
List list= q.list(); 
return list;
}

 

就会遇见这样的问题

解决办法很简单

我们都知道hibernateDAO 是继承 HibernateDaoSupport

我们就可以调用父类下面的releaseSession(Session)方法来舍弃这个session

这里session.close()和session.clear()方法是没有作用的 切记

所以上面的方法只要加一行代码就可以了

   

public List findPageService(int pageNow,int pageSize)
{ 
String hql="。。。。。。。。。。。。。";
Session session=getHibernateTemplate().getSessionFactory().openSession();
Query q= session.createQuery(hql);
int first=(pageNow-1)*pageSize;
q.setFirstResult(first);
q.setMaxResults(pageSize);
List list= q.list(); 
super.releaseSession(session); 

return list;
}

 

注意:如果有多对一关系的话这里我们需要设置<many-to-one>里的lazy属性为false

还有一种方法是用sping管理session方法

getHibernateTemplate().executeFind()包住查询代码就OK了,spring会自动插入关闭当前session的代码


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值