Transaction Control Language 事务控制语言
事务:
经典案例:转账
张三丰 1000
郭襄 1000
update 表 set 张三丰的余额=500 where name=‘张三丰‘
意外
update 表 set 郭襄的余额=1500 where name=‘郭襄‘
比如insert、update、delete语句
delete from 表 where id =1;
前提:必须先设置自动提交功能为禁用(只针对当前的事务有效)
set autocommit=0;
步骤1:开启事务
set autocommit=0;
start transaction;可选的
步骤2:编写事务中的sql语句(select insert update delete)
语句1;
语句2;
...
步骤3:结束事务
方式一:commit;提交事务
方式二:rollback;回滚事务
savepoint 节点名;设置保存点
SELECT * FROM account;
SET autocommit=0;
START TRANSACTION;
DELETE FROM account;
ROLLBACK;
SELECT * FROM account;
在典型的应?程序中,多个事务并发运?,经常会操作相同的数据来完成各?的任务(多个?户对同?数据进?操作)。并发虽然是必须的,但可能会导致以下的问题。
脏读(Dirty read): 当?个事务正在访问数据并且对数据进?了修改,?这种修改还没有提交到数据库中,这时另外?个事务也访问了这个数据,然后使?了这个数据。因为这个数据是还没有提交的数据,那么另外?个事务读到的这个数据是“脏数据”,依据“脏数据”所做的操作可能是不正确的。
不可重复读(Unrepeatableread): 指在?个事务内多次读同?数据。在这个事务还没有结
束时,另?个事务也访问该数据。那么,在第?个事务中的两次读数据之间,由于第?个事务的修改导致第?个事务两次读取的数据可能不太?样。这就发?了在?个事务内两次读到的数据是不?样的情况,因此称为不可重复读。
幻读(Phantom read): 幻读与不可重复读类似。它发?在?个事务(T1)读取了??数
据,接着另?个并发事务(T2)插?了?些数据时。在随后的查询中,第?个事务(T1)就会发现多了?些原本不存在的记录,就好像发?了幻觉?样,所以称为幻读。
丢失修改(Lost to modify): 指在?个事务读取?个数据时,另外?个事务也访问了该数
据,那么在第?个事务中修改了这个数据后,第?个事务也修改了这个数据。这样第?个事务内的修改结果就被丢失,因此称为丢失修改。 例如:事务1读取某表中的数据A=20,事务2也读取A=20,事务1修改A=A-1,事务2也修改A=A-1,最终结果A=19,事务1的修改被丢失。
不可重复读和幻读区别:
不可重复读的重点是修改?如多次读取?条记录发现其中某些列的值被修改,幻读的重点在于新
增或者删除?如多次读取?条记录发现记录增多或减少了。
原文:https://www.cnblogs.com/BigMonster-S/p/14916449.html