SQL语言的学习:TCL
TCL语言(事务控制语言):
-
Transaction Control Language 事务控制语言
-
事务:
- 一个或一组sql语句组成一个执行单元,这个执行单元要么全部执行,要么全部不执行。
-
经典案例:转账
张三丰 1000
郭襄 1000
update 表 set 张三丰的余额=500 where name=‘张三丰‘
意外
update 表 set 郭襄的余额=1500 where name=‘郭襄‘
事务的属性:ACID(原子性|一致性|隔离性|持久性)
原?性(Atomicity):
- 事务是最?的执?单位,不允许分割。事务的原?性确保动作要么全部完成,要么完全不起作?;
?致性(Consistency):
- 执?事务前后,数据保持?致,多个事务对同?个数据读取的结果是相同的;
隔离性(Isolation):
- 并发访问数据库时,?个?户的事务不被其他事务所?扰,各并发事务之间数据库是独?的;(通过隔离级别来实现,可能达不到完全独立)
持久性(Durability):
- ?个事务被提交之后。它对数据库中数据的改变是持久的,即使数据库发?故障也不应该对其有任何影响。
事务的创建:
隐式事务:事务没有明显的开启和结束的标记
比如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 节点名;设置保存点
演示事务的使用步骤
- 开启事务
SET autocommit=0;
START TRANSACTION;
- 编写一组事务的语句
UPDATE account SET balance = 1000 WHERE username=‘张无忌‘;
UPDATE account SET balance = 1000 WHERE username=‘赵敏‘; - 结束事务
ROLLBACK; //如果是已经结束事务后(commit)再提交回滚,不会对结果进行改变;因为内容已经从内存提交到磁盘中。
//commit;
SELECT * FROM account;
- 演示事务对于delete和truncate的处理的区别
SET autocommit=0;
START TRANSACTION;
DELETE FROM account;
ROLLBACK;
- 演示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;
并发事务带来哪些问题:
-
在典型的应?程序中,多个事务并发运?,经常会操作相同的数据来完成各?的任务(多个?户对同?数据进?操作)。并发虽然是必须的,但可能会导致以下的问题。
-
脏读(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的修改被丢失。 -
不可重复读和幻读区别:
不可重复读的重点是修改?如多次读取?条记录发现其中某些列的值被修改,幻读的重点在于新
增或者删除?如多次读取?条记录发现记录增多或减少了。