MySQL_I
oDB之事务与锁详解之事务与锁与锁详解
引题:为何引入事务?引题:为何引入事务?引入事务1数据完整性数据完整性2数据安全性数据安全性3充分利用系统资源,提高系统并发处理的能力充分利用系统资源,提高系统并发处理的能力充分利用系统资源系统并发1事务的特征事务具有四个特性:原子性(Atomiocity)、一致性(Co
siste
cy)、隔离性(Isolatio
)和持久性(Durability),这四个特性简称ACID特性。11原子性事务是数据库的逻辑工作单位,事务中包括的所有操作要么都做,要么都不做。12一致性事务执行的结果必须是使数据库从一个一致性的状态变到另外一个一致性状态。13隔离性一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对其他事务是隔离的,并发执行的各个事务之间互相不干扰。14持久性一个事务一旦成功提交,对数据库中数据的修改就是持久性的。接下来其他的其他操作或故障不应该对其执行结果有任何影响。2MySQL的I
oDB引擎中事物与锁21SELECT……LOCKINSHAREMODE会话事务中查找的数据,加上一个共享锁。若会话事务中查找的数据已经被其他会话事务加上独占锁的话,共享锁会等待其结束再加,若等待时间过长就会显示事务需要的锁等待超时。22SELECT…FORUPDATE会话事务中查找的数据,加上一个读更新琐,其他会话事务将无法再加其他锁,必须等待其结束。23INSERT、UPDATE、DELETE、、会话事务会对DML语句操作的数据加上一个独占锁,其他会话的事务都将会等待其释放独占锁。
f24gapa
d
extkeylock(间隙锁)(间隙锁)I
oDB引擎会自动给会话事务中的共享锁、更新琐以及独占锁,需要加到一个区间值域的时候,再加上个间隙锁(或称范围锁),对不存在的数据也锁住,防止出现幻写。备注:备注:以上21,22,23,24中描述的情况,跟MySQL所设置的事务隔离级别也有关系。3四种事务隔离模式四种事务隔离模式四种事务31READUNCOMMITEDSELECT的时候允许脏读,即SELECT会读取其他事务修改而还没有提交的数据。32READCOMMITEDSELECT的时候无法重复读,即同一个事务中两次执行同样的查询语句,若在第一次与第二次查询之间时间段,其他事务又刚好修改了其查询的数据且提交了,则两次读到的数据不一致。33REPEATABLEREADSELECT的时候可以重复读,即同一个事务中两次执行同样的查询语句,得到的数据始终都是一致的。34SERIALIZABLE与可重复读的唯一区别是,默认把普通的SELECT语句改成SELECT…LOCKINSHAREMODE。即为查询语句r