事务控制语言DTL

Posted gaogzhen

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了事务控制语言DTL相关的知识,希望对你有一定的参考价值。

一、什么是事务?

·  数据库中的事务,是指可以将“多条相关语句执行”看做是“一条语句执行”的一种内部机制。即事务是一种可以保证“多条语句一次性执行完成”或者一条语句都不执行的机制。

 

 

三、事务的特点

  • 原子性--事务中的语句,应该都能做到,要么全部完成,要么都不做。
  • 一致性--让数据保持逻辑上的“合理性”
  • 隔离性--如果多个事务同时并发执行,但每个事务就像独立运行一样
  • 持久性--一个事务执行成功,就明确物理硬盘的数据改变

四、事务模式

  事务模式:就是让每条执行语句当做“一个事务”的设定项。

  •   mysql安装好之后,默认其事务模式是:一条语句就是一个事务既(autocommit=1)
  •   可以将其设定为“认可”模式--既执行“commit;”语句才生效 ,set autocommit=0,关闭该模式示例:

  技术分享图片

update test set num=20 where id = 1;

  技术分享图片更改事务模式

 set autocommit = 0;

技术分享图片再次执行更改数据语句:

 update test set num=31 where id = 1;

  结果:技术分享图片执行 commit;  技术分享图片

五、事务的基本执行流程

  1. 事务声明开始:start transaction;
  2. 设定多条要执行的具体语句。比如,inesert,update,delete,...
    1. 其实只是“执行”,并不“‘生效’”--只是在内存状态下的执行,而不是在物理状态的执行
  3. 判断是否需要执行这些语句:

    if(判断错误条件) {

      //语句执行;

      commit;//这时才生效--物理状态既写入硬盘

    }

    else {

      rollback;//回滚--不执行任何语句

    }

    判断错误条件通常在以下2种环境:

    1. 命令行(cmd)环境,直接观察
    2. 如果是php程序,用mysqli_error()函数判断

二、为什么需要事务?

  举例:

id account(账户) deposit(存款)
1 test01 1000
2 test02 5000

  表(saving)

  test01和test02认识且在不同城市,test01想购买iPhone7(5000元),想向test02借4000元,上图为2人在银行存款

  银行转账:

    第一步:update saving set deposit=deposit-4000 where id = 2;

    第二步:update saving set deposit=deposit+4000 where id = 1;

    如果上面2步都没有错误,则执行:

    commit;//执行

    如果又错误,则可以:

    rollback;//回滚到最初状态

  事务可以看做是一个“容器”,将多条语句放入该“容器”,最后只要一个命令行,来决定是否执行该“容器”

   技术分享图片结果:技术分享图片

  还钱:技术分享图片结果:技术分享图片

以上是关于事务控制语言DTL的主要内容,如果未能解决你的问题,请参考以下文章

数据库事务-DTL事务控制语句

sql语言是啥语言?

DDL

11. sql DDL

DJango模块语言(DTL)语法简单介绍

Oracle DDL 数据定义语言