spring boot 获取session

   今天做项目的时候,遇到了一个巨坑,我们的项目是spring boot 为架构! 然而我在做一个查询的时候,数据少还好,当我一次性查个几百条数据的时候,数据库就崩溃了.直接报数据库连接断掉,后来百度后发现是session的问题:

之前代码:

@Autowired
private EntityManagerFactory entityManagerFactory;
public Session getSession() {
   Session session = entityManagerFactory.unwrap(SessionFactory.class).openSession();
   return session;
}

发现用了session中openSession..................

openSession与getCurrentSession的区别

1. openSession 从字面上可以看得出来,是打开一个新的session对象,而且每次使用都是打开一个新的session,假如连续使用多次,则获得的session不是同一个对象,并且使用完需要调用close方法关闭session。

2. getCurrentSession ,从字面上可以看得出来,是获取当前上下文一个session对象,当第一次使用此方法时,会自动产生一个session对象,并且连续使用多次时,得到的session都是同一个对象,这就是与openSession的区别之一,简单而言,getCurrentSession 就是:如果有已经使用的,用旧的,如果没有,建新的。

发现了问题,我迅速将openSession改为getCurrentSession,这下肯定没问题...............(看来是我想多了) 直接访问就报错,一个头两个大,说的好像是找不到session的错误,然后又是一顿百度,询问大佬.找了大半天,发现了一个配置的问题:

原配置:

spring.jpa.properties.hibernate.current_session_context_class=org.springframework.orm.hibernate4.SpringSessionContext

改后的配置:

spring.jpa.properties.hibernate.current_session_context_class=org.springframework.orm.hibernate5.SpringSessionContext

发现问题没有,4和5的区别,具体的我也不清楚为什么会这样,反正问题解决了,能够及时的释放连接,不会导致数据库崩溃了.....开心!但是如果有大佬知道什么原因,还请大佬们不惜赐教!!!小弟感激不尽

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值