博客
关于我
Hibernate入门(五)---------事务管理
阅读量:423 次
发布时间:2019-03-06

本文共 1233 字,大约阅读时间需要 4 分钟。

  在Hibernate中,可以通过代码来操作管理事务,如通过“Transaction tx = session.beginTransaction()”,开启一个事务,持久化操作后,通过"tx.commit()",提交事务,如果事务出现异常又通过"tx.rollback()".操作来撤销事务(事务回滚)。

  除了在代码中对事务开启,提交和回滚操作外,还可以在Hibernate的配置文件中对事务进行配置,配置文件中,可以设置事务的隔离级别。其具体的配置方法是在hibernate.cfg.xml文件中的<session-factory>标签中进行的。配置方法如下:

  

如何保证在Service中开启事务时使用的Session对象和DAO中多个操作使用的是同一个Session对象。

  其实有两种办法可以实现:

    1.可以在业务层获取到Session,并将Session作为参数传递给DAO。

    2.可以使用ThreadLocal将业务层获取到的Session绑定到当前线程中,然后在DAO中获取Session的时候,都从当前线程中获取。

  其实使用第二种方式肯定是最优方案,那么具体的实现已经不用我们来完成了,Hibernate的内部已经将这个事情做完了。我们只需要完成一段配置即可。

  Hibernate5自身提供了三种管理Session对象的方法:

    Session对象的生命周期与本地线程绑定

    Session对象的生命周期与JTA事务绑定

    Hibernate委托程序管理Session对象的生命周期

  在Hibernate的配置文件中,hibernate current_session_context_class 属性用于指定Session管理方式 可选值包括:

    thread:Session 对象的生命周期与本地线程绑定。

    jta:Session对象的生命周期与JTA事务绑定

    managed:Hibernate委托程序来管理Session对象的生命周期

  在hibernate.cfg.xml中进行如下配置;

<!--配置session绑定本地线程 -->
thread>

  hibernate提供sessionFactory.getCurrentSession()创建一个session和ThreadLocal绑定方法:

  在HibernateUtil工具类中更改getCurrentSession方法;

//获取当前线程绑定的会话public static Session getCurrentSession(){    return sessionFactory.getCurrentSession();   }

  而且Hibernate中提供的这个与线程绑定的session可以不用关闭,当线程执行结束后,就会自动关闭了。

转载地址:http://vyuuz.baihongyu.com/

你可能感兴趣的文章
MySQL I 有福啦,窗口函数大大提高了取数的效率!
查看>>
mysql id自动增长 初始值 Mysql重置auto_increment初始值
查看>>
MySQL in 太多过慢的 3 种解决方案
查看>>
MySQL InnoDB 三大文件日志,看完秒懂
查看>>
Mysql InnoDB 数据更新导致锁表
查看>>
Mysql Innodb 锁机制
查看>>
MySQL InnoDB中意向锁的作用及原理探
查看>>
MySQL InnoDB事务隔离级别与锁机制深入解析
查看>>
Mysql InnoDB存储引擎 —— 数据页
查看>>
Mysql InnoDB存储引擎中的checkpoint技术
查看>>
Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
查看>>
MySQL InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql innodb通过使用mvcc来实现可重复读
查看>>
mysql insert update 同时执行_MySQL进阶三板斧(三)看清“触发器 (Trigger)”的真实面目...
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
Mysql join原理
查看>>
MySQL Join算法与调优白皮书(二)
查看>>
Mysql order by与limit混用陷阱
查看>>