getCurrentSession与getSession之关系

采用getCurrentSession()创建的session会绑定到当前线程中,而采用openSession()创建的session则不会采用getCurrentSession()创建的session在commit或rollback时会自动关闭,而采用openSession()创建的session必须手动关闭2、使用getCurrentSession()需要在hibernate.cfg.xml文件中加入如下配置:
   * 如果使用的是本地事务(jdbc事务)<property name="hibernate.current_session_context_class">thread</property>
   * 如果使用的是全局事务(jta事务)<property name="hibernate.current_session_context_class">jta</property>

         在3.0版本之前,使用Hibernate的程序要么采用自行编写的基于 ThreadLocal的上下文session,要么采用HibernateUtil这样的辅助类,要么采用第三方框架(比如Spring或Pico),它们提供了基于代理(proxy)或者基于拦截器(interception)的上下文相关session。 
利于ThreadLocal模式管理Session
   早在Java1.2推出之时,Java平台中就引入了一个新的支持:java.lang.ThreadLocal,给我们在编写多线程程序时提供了一种新的选择。ThreadLocal是什么呢?其实ThreadLocal并非是一个线程的本地实现版本,它并不是一个Thread,而是thread local variable(线程局部变量)。也许把它命名为ThreadLocalVar更加合适。线程局部变量(ThreadLocal)其实的功用非常简单,就是为每一个使用某变量的线程都提供一个该变量值的副本,是每一个线程都可以独立地改变自己的副本,而不会和其它线程的副本冲突。从线程的角度看,就好像每一个线程都完全拥有一个该变量。 

        ThreadLocal是如何做到为每一个线程维护变量的副本的呢?其实实现的思路很简单,在ThreadLocal类中有一个Map,用于存储每一个线程的变量的副本。比如下面的示例实现(为了简单,没有考虑集合的泛型): 

 public  class  HibernateUtil  {
 public static final ThreadLocal session =new ThreadLocal();
 public  static  final  SessionFactory  sessionFactory;
  static  {
      try  {
        sessionFactory  =  new  Configuration().configure().buildSessionFactory();
      } catch (Throwable  ex) {
           throw  new  ExceptionInInitializerError(ex);
      }     
 }
 
     public  static  Session  currentSession()  throws  HibernateException  {
        Session  s  =  session.get();
        if(s  ==  null)  {
          s  =  sessionFactory.openSession();
          session.set(s);
           }
         return  s;
       }
    public  static  void  closeSession()  throws  HibernateException  {
           Session  s  =  session.get();
        if(s  !=  null)  {
            s.close();
        }
        session.set(null);
    }
 }


openSession() 与 getCurrentSession() 有何不同和关联呢?
    在 SessionFactory 启动的时候, Hibernate 会根据配置创建相应的 CurrentSessionContext ,在 getCurrentSession() 被调用的时候,实际被执行的方法是 CurrentSessionContext.currentSession() 。在 currentSession() 执行时,如果当前 Session 为空, currentSession 会调用 SessionFactory 的 openSession 。所以 getCurrentSession() 对于 Java EE 来说是更好的获取 Session 的方法。


原文

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你好!关于您提到的问题,可能是由于批量更新时的事务管理配置不正确导致的。在 Hibernate 中,批量更新操作需要在同一个事务中进行,以确保数据的一致性和完整性。 以下是一些可能导致您遇到问题的原因和解决方案: 1. 没有正确配置事务管理器:请确认您的 Hibernate 配置文件中是否正确配置了事务管理器。在 Hibernate 中,可以使用诸如 JTA、JDBC 或 Spring 的事务管理器来管理事务。确保您选择了适合您项目的事务管理器,并正确配置它。 2. 没有显式地开启事务:在进行批量更新操作之前,您需要显式地开启一个事务。您可以使用 `beginTransaction()` 方法来开启一个事务,并在批量更新操作完成后使用 `commit()` 方法提交事务。 3. 批量更新操作没有在同一个事务中:确保您的批量更新操作都在同一个事务中进行。可以使用 Hibernate 的 `Session` 对象来执行批量操作,确保在同一个事务中执行。 以下是一个示例代码片段,展示了如何正确地进行批量更新操作: ``` Session session = sessionFactory.getCurrentSession(); Transaction transaction = null; try { transaction = session.beginTransaction(); // 执行批量更新操作 // ... transaction.commit(); } catch (Exception e) { if (transaction != null) { transaction.rollback(); } // 处理异常 } finally { session.close(); } ``` 请注意,上述代码中的 `sessionFactory` 是 Hibernate 的会话工厂对象,您需要将其替换为您项目中实际使用的会话工厂。 希望这些解决方案可以帮助您解决问题!如果您有任何进一步的问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值