博客
关于我
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/

你可能感兴趣的文章
mysql5.7 安装版 表不能输入汉字解决方案
查看>>
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>
mysql5.7免费下载地址
查看>>
mysql5.7命令总结
查看>>
mysql5.7安装
查看>>
mysql5.7性能调优my.ini
查看>>
MySQL5.7新增Performance Schema表
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Webpack 之 basic chunk graph
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>
Mysql8.0以上重置初始密码的方法
查看>>