SQL语言的学习:TCL

SQL语言的学习:TCL

TCL语言(事务控制语言):

  • Transaction Control Language 事务控制语言

  • 事务:

    • 一个或一组sql语句组成一个执行单元,这个执行单元要么全部执行,要么全部不执行。
  • 经典案例:转账

张三丰 1000
郭襄 1000

update 表 set 张三丰的余额=500 where name=‘张三丰‘
意外
update 表 set 郭襄的余额=1500 where name=‘郭襄‘
SQL语言的学习:TCL
SQL语言的学习:TCL

事务的属性: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 节点名;设置保存点

演示事务的使用步骤

  1. 开启事务
    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;

  1. 演示事务对于delete和truncate的处理的区别

SET autocommit=0;
START TRANSACTION;

DELETE FROM account;
ROLLBACK;

  1. 演示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的修改被丢失。

  • 不可重复读和幻读区别:
    不可重复读的重点是修改?如多次读取?条记录发现其中某些列的值被修改,幻读的重点在于新
    增或者删除?如多次读取?条记录发现记录增多或减少了。

SQL语言的学习:TCL

上一篇:Mysql修改表名


下一篇:mysql 主从同步