实现hibernate中每条线程有一个自己的Session实例

为什么我们为每条线程创建自己的Session实例:

  • SessionFactory是线程安全的(Thread-Safe),可以让多个执行线程同时存取SessionFactory而不会有数据共享的问题。
  • 会话工厂缓存了生成的SQL语句和Hibernate在运行时使用的映射元数据。
  •  需要注意的是SessionFactory是重量级的,因为一 般情况下,一个项目通常只需要一个SessionFactory就够(单例模式),当需要操作多个数据库时,可以为每个数据库指定一个SessionFactory。
Session接口负责执行被持久化对象的CRUD操作(CRUD的任务是完成与数据库的交流):
  • Session也称为持久化管理器,因为它是与持久化有关的操作接口。
  • Session不是线程安全的,应该避免多个线程共享同一个Session实例。
  •  Session通过SessionFactory打开,在所有的工作完成后,需要关闭。

其中可以通过以下方式实现每一个线程中有一个Session实例

  1. getCurrentSession (Hibernate 3)
  2. 可以采用ThreadLocal的办法。(Hibernate 2)
  3. 把Session对象放在方法内部定义
下面我们采用第二种方法(ThreadLocal)来实现它。

import java.util.function.*;
import org.hibernate.*;
import org.hibernate.cfg.*;
public class Util
{
    private static final SessionFactory sessionFactory=new Configuration().configure().buildSessionFactory();
    private static final ThreadLocal<Session> threadLocal=ThreadLocal.withInitial(new Supplier<Session>()
    {
        public Session get()
        {
            return sessionFactory.openSession();
        }
    });
    public static Session getSession()
    {
        //由"ThreadLocal.withInitial"中的Supplier参数确保get返回值必不为空。  
        return threadLocal.get();
    }
    public static void closeSession()
    {
        //由"ThreadLocal.withInitial"中的Supplier参数确保get返回值必不为空。  
        threadLocal.get().close();
        //移除ThreadLocal中的Session,确保下次调用get方法重新调用"ThreadLocal.withInitial"中的Supplier参数。  
        threadLocal.remove();
    }
}




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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值