事务是什么?
事务(Transaction),一般是指要做的或所做的事情。在计算机术语中是指访问并可能更新数据库中各种数据项的一个程序执行单元(unit)。
例如:在关系数据库中,一个事务可以是一条SQL语句,一组SQL语句或整个程序。
事务应该具有4个属性: 原子性、一致性、隔离性、持久性 。这四个属性通常称为ACID特性。
事务特性 | 含义 |
---|---|
原子性(atomicity) | 一个事务是一个不可分割的工作单位,事务中包括的操作要么都做,要么都不做。 |
一致性(consistency) | 事务必须是使数据库从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。 |
隔离性(isolation) | 一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰 |
持久性(durability) | 持久性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响 |
不考虑隔离性引发安全性问题
**脏读 :**在一个事务中读取到另一个事务没有提交的数据
**不可重复读:**在一个事务中,两次查询的结果不一致(针对的update操作)
**虚读(幻读):**在一个事务中,两次查询的结果不一致(针对的insert操作)
解决以上的问题,要该怎么办呢?答案是利用spring事务隔离API
隔离级别 | 含义 | 读脏数据 | 不可重复读 | 幻读 |
---|---|---|---|---|
DEFAULT | 使用数据库默认的事务隔离级别 | - | - | - |
READ_UNCOMMITTED | 一个事务可以读取到另一个事务未提交的事务记录。 | 未解决 | 未解决 | 未解决 |
READ_COMMITTED | 一个事务只能读取到已经提交的记录,不能读取到未提交的记录。 | 解决 | 未解决 | 未解决 |
REPEATABLE_READ | 一个事务可以多次从数据库读取某条记录,而且多次读取的那条记录都是一致的,相同的 | 解决 | 解决 | 未解决 |
SERIALIZABLE | 事务执行时,会在所有级别上加锁,事务是以串行的方式进行的,而不是一起发生的。但是,会带来性能的下降。 | 解决 | 解决 | 解决 |