美文网首页
Hibernate中的事务与并发

Hibernate中的事务与并发

作者: Michael_林 | 来源:发表于2017-04-29 16:28 被阅读123次

Hibernate中的事务与并发


事务相关的概念

  1. 什么是事务

    • 事务就是逻辑上的一组操作,组成事务的各个执行单元,操作要么全都成功,要么全都失败.
    • 转账的例子:冠希给美美转钱,扣钱,加钱。两个操作组成了一个事情!
  2. 事务的特性

    • 原子性 -- 事务不可分割.
    • 一致性 -- 事务执行的前后数据的完整性保持一致.
    • 隔离性 -- 一个事务执行的过程中,不应该受到其他的事务的干扰.
    • 持久性 -- 事务一旦提交,数据就永久保持到数据库中.
  3. 如果不考虑隔离性:引发一些读的问题

    • 脏读 -- 一个事务读到了另一个事务未提交的数据.
    • 不可重复读 -- 一个事务读到了另一个事务已经提交的update数据,导致多次查询结果不一致.
    • 虚读 -- 一个事务读到了另一个事务已经提交的insert数据,导致多次查询结构不一致.
  4. 通过设置数据库的隔离级别来解决上述读的问题

    • 未提交读:以上的读的问题都有可能发生.
    • 已提交读:避免脏读,但是不可重复读,虚读都有可能发生.
    • 可重复读:避免脏读,不可重复读.但是虚读是有可能发生.
    • 串行化:以上读的情况都可以避免.
  5. 如果想在Hibernate的框架中来设置隔离级别,需要在hibernate.cfg.xml的配置文件中通过标签来配置

    • 通过:hibernate.connection.isolation = 4 来配置
    • 取值
        1. —Read uncommitted isolation
        1. —Read committed isolation
        1. —Repeatable read isolation
        1. —Serializable isolation

丢失更新的问题

  1. 如果不考虑隔离性,也会产生写入数据的问题,这一类的问题叫丢失更新的问题。

  2. 例如:两个事务同时对某一条记录做修改,就会引发丢失更新的问题。

    • A事务和B事务同时获取到一条数据,同时再做修改
    • 如果A事务修改完成后,提交了事务
    • B事务修改完成后,不管是提交还是回滚,如果不做处理,都会对数据产生影响
  3. 解决方案有两种

    • 悲观锁

      • 采用的是数据库提供的一种锁机制,如果采用做了这种机制,在SQL语句的后面添加 for update 子句
        • 当A事务在操作该条记录时,会把该条记录锁起来,其他事务是不能操作这条记录的。
        • 只有当A事务提交后,锁释放了,其他事务才能操作该条记录
    • 乐观锁

      • 采用版本号的机制来解决的。会给表结构添加一个字段version=0,默认值是0
        • 当A事务在操作完该条记录,提交事务时,会先检查版本号,如果发生版本号的值相同时,才可以提交事务。同时会更新版本号version=1.
        • 当B事务操作完该条记录时,提交事务时,会先检查版本号,如果发现版本不同时,程序会出现错误。
  4. 使用Hibernate框架解决丢失更新的问题

    • 悲观锁

      • 使用session.get(Customer.class, 1,LockMode.UPGRADE); 方法
    • 乐观锁

      • 1.在对应的JavaBean中添加一个属性,名称可以是任意的。例如:private Integer version; 提供get和set方法
      • 2.在映射的配置文件中,提供<version name="version"/>标签即可。
Paste_Image.png

绑定本地的Session

  1. 之前在讲JavaWEB的事务的时候,需要在业务层使用Connection来开启事务,

    • 一种是通过参数的方式传递下去
    • 另一种是把Connection绑定到ThreadLocal对象中
  2. 现在的Hibernate框架中,使用session对象开启事务,所以需要来传递session对象,框架提供了ThreadLocal的方式

    • 需要在hibernate.cfg.xml的配置文件中提供配置

      • <property name="hibernate.current_session_context_class">thread</property>
    • 重新HibernateUtil的工具类,使用SessionFactory的getCurrentSession()方法,获取当前的Session对象。并且该Session对象不用手动关闭,线程结束了,会自动关闭。
      public static Session getCurrentSession(){
      return factory.getCurrentSession();
      }

    • 注意:想使用getCurrentSession()方法,必须要先配置才能使用。 Session.flush() -- 刷出缓存

相关文章

  • Hibernate中的事务与并发

    Hibernate中的事务与并发 事务相关的概念 什么是事务事务就是逻辑上的一组操作,组成事务的各个执行单元,操作...

  • Hibernate

    1、什么是Hibernate的并发机制?怎么去处理并发问题? Hibernate并发机制: a、Hibernate...

  • Hibernate事务与并发问题处理(乐观锁与悲观锁)----

    目录 一、数据库事务的定义 二、数据库事务并发可能带来的问题 三、数据库事务隔离级别 四、使用Hibernate设...

  • Hibernate体系结构

    Hibernate架构包括许多对象持久对象,会话工厂,事务工厂,连接工厂,会话,事务等。 hibernate架构中...

  • 事务的隔离、传播、回滚

    springboot之事务的隔离与传播 事务的隔离 多个事务是并发的访问数据库,并发是必须的但会带来几个问题: 脏...

  • 详解Spring的事务管理PlatformTransaction

    常规的事务大致有许多种,比如jdbc事务, Hibernate的事务, JpaTransactionObject事...

  • 事务与并发

    思考 测试环境:springboot+mysql。现在有这么一个场景,有一个接口,每请求一次商品库存减一,该接口已...

  • hibernate体系结构

    Hibernate包括很多对象持久对象,会话工厂、事务工厂、链接工厂、会话、事务等。Hibernate中有4层:J...

  • 数据库事务--事务隔离级别

    数据库里关于事务的并发问题,也叫做竞态条件(race condition)。它是描述并发事务中,一个事务需要读取另...

  • 2019-03-18文章精选

    1.深入理解 MySQL ——锁、事务与并发控制 各种锁、事务与并发,写得很详细。 2.剖析分布式锁 redis部...

网友评论

      本文标题: Hibernate中的事务与并发

      本文链接:https://www.haomeiwen.com/subject/okwzzttx.html