事务的相关概念
什么是事务
- 事务是逻辑上的一组操作,组成事务的各个执行单元,操作要么全都成功,要么全部失败
- 转账的例子:小王给小李转钱,扣钱,加钱,两个操作组成了一个事务
事务的特性
- 一致性----事务执行的前后数据的完整性保持一致
- 隔离性-----一个事务执行的过程中,不应该受到其他的事务的干扰
- 持久性----事务一旦提交,数据就永久保持到数据库中
如果不考虑隔离性:引发一些读的问题
- 不可重复读-----一个事务读到了另一个事务已经提交的update数据,导致多次查询结果不一致。
- 虚读----一个事务读到了另一个事务已经提交的inset数据,导致多级查询机构不一致。
通过设置数据库的隔离级别来解决上述读的问题
- 已提交读:避免脏读,但是不可重复读,虚读都有可能发生
- 可重复读:避免脏读,不可重复读,但是虚读是有可能发生
- 串行化:以上读的情况都可以避免
如果想在Hibernate的框架中来设置隔离级别,需要在Hibernate.cfg.xml的配置文件中通过标签来配置
- 通过:hibernate.connection,isolation = 4 来配置
- 取值:
- 1——Read uncommitted isolation
- 2——Read commited isolation
- 4——Repeatable read isolation
- 8——Serializable isolation
<!--设置数据库的隔离级别,就使用默认值就OK-->
<property name="hibernate.connection.isolation">4</property>
丢失更新的问题
- 如果不考虑隔离性,也会产生写入数据的问题,这一类的