TCL:Transaction Control Language 事务控制语言
事务:
一个或一组sql语句组成一个执行单元,这个执行单元要么全部执行,要么全部不执行。
案例:经典案例,数据转移,例如皮卡丘和喷火龙初始都有1000元
皮卡丘 1000
喷火龙 1000
喷火龙想要把自己的500给皮卡丘。此时我们需要进行修改
update 表 set 喷火龙余额=500 where name=‘喷火龙’
但在进行上一句语句之后出现了意外,导致下一句语句执行失败
update 表 set 皮卡丘的余额=1500 where name=‘皮卡丘’
此时结果将返回
皮卡丘 1000
喷火龙 500
不符合我们想要的结果。因此需要通过事务来将上述语句捆绑在一起。
面试经典题
事务的ACID属性
1.原子性
事务是不可分割的工作单位,事务中的操作都发生或者都不发生2.一致性
事务必须使数据库从一个一致性状态变换到另外一个一致性状态3.隔离性
一个事务的执行不被其他事务干扰,一个事务内部操作使用的数据对其他事务隔离,并且各个事务之间互不干扰4.持久性
一个事务一旦提交,数据库的改变永久 2.事务的创建
隐式事务:事务没有明显的开启和结束的标记
比如insert、update、delete语句
delete from 表 where id =1;
mysql默认上述语句为一个事务。
显式事务:事务具有明显的开启和结束的标记
前提:必须先设置自动提交功能为禁用
set autocommit=0;
步骤1:开启事务
set autocommit=0;
步骤2:编写事务中的sql语句(select insert update delete)
语句1;
语句2;
…
步骤3:结束事务
commit;提交事务
rollback;回滚事务
savepoint 节点名;设置保存点
事务的隔离级别:
脏读 不可重复读 幻读
read uncommitted:√ √ √
read committed: × √ √
repeatable read: × × √
serializable × × ×
mysql中默认 第三个隔离级别 repeatable read
oracle中默认第二个隔离级别 read committed
查看隔离级别
select @@tx_isolation;
设置隔离级别
set session|global transaction isolation level 隔离级别;
脏读:还没有更新就被读了
不可重复读:
幻读:
SHOW VARIABLES LIKE ‘autocommit’;
#1.演示事务的使用步骤
#开启事务
SET autocommit=0;
START TRANSACTION;
#编写一组事务的语句
UPDATE account SET balance = 1000 WHERe username='皮卡丘';UPDATE account SET balance = 1000 WHERe username='喷火龙';
#结束事务
回滚:ROLLBACK; 不执行事务
提交:commit;执行事务
SELECT * FROM account;
#2.演示savepoint 的使用
SET autocommit=0;START TRANSACTION;DELETe FROM account WHERe id=25;SAVEPOINT a;#设置保存点DELETe FROM account WHERe id=28;ROLLBACK TO a;#回滚到保存点SELECt * FROM account;
上述只删除了25号的数据,28号的数据为删除
演示事务对于delete和truncate的处理的区别
SET autocommit=0;START TRANSACTION;DELETE FROM account;ROLLBACK;
delete支持回滚
SET autocommit=0;START TRANSACTION;DELETE FROM account;ROLLBACK;
使用truncate不支持回滚