回顾一下事务:
一、事务特性:acid
(1)原子性(Atomicity)
原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚
因此事务的操作如果成功就必须要完全应用到数据库,如果操作失败则不能对数据库有任何影响。
(2)一致性(Consistency)
一致性是指事务必须使数据库从一个一致性状态 变换到 另一个一致性状态,也就是说一个事务执行之前和执行之后都必须
处于一致性状态。
就好比转账,假设用户A和用户B两者的钱加起来一共是2000,那么不管A和B之间如何转账,转几次账,事务结束后两个用户
的钱相加起来应该还得是2000,这就是事务的一致性。
(3)隔离性(Isolation)
隔离性是当多个用户并发访问数据库时,比如操作同一张表时,数据库为每一个用户开启的事务,不能被其他事务的操作
所干扰,多个并发事务之间要相互隔离。
(4)持久性(Durability)
持久性是指一个事务一旦被提交了,那么对数据库中的数据的改变就是永久性的,即便是在数据库系统遇到故障的情况下
也不会丢失提交事务的操作。
二、事务的并发问题
(1)脏读
脏读是指在一个事务处理过程里读取了另一个未提交的事务中的数据。
(2)幻读(虚读)
不可重复读是指在对于数据库中的某个数据,一个事务范围内多次查询却返回了不同的数据值,这是由于在查询间隔,
被另一个事务修改并提交了。
(3)不可重复读
幻读是事务非独立执行时发生的一种现象。例如事务T1对一个表中所有的行的某个数据项做了从“1”修改 为“2”的操作,这时
事务T2又对这个表中插入了一行数据项,而这个数据项的数值还是为“1”并且提交给数据库。而操作事务T1的用户如果再查看刚
刚修改的数据,会发现还有一行没有修改,其实这行是从事务T2中添加的,就好像产生幻觉一样,这就是发生了幻读。
三、隔离级别
(1)read-uncommitted 读未提交: 最低级别,任何情况都无法保证。
(2)read-committed 读提交:可避免脏读的发生。
(3)repeatable-read 可重复读:可避免脏读、不可重复读的发生。
(4)serializable 可串行化: 可避免脏读、不可重复读、幻读的发生。
在MySQL数据库中查看当前事务的隔离级别:
select @@tx_isolation;
在MySQL数据库中设置事务的隔离 级别:
set [glogal | session] transaction isolation level 隔离级别名称;
set tx_isolation=’隔离级别名称;’
ps:设置数据库的隔离级别一定要是在开启事务之前!