一、什么是事务?

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

三、事务的特点

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

四、事务模式

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

  •   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的更多相关文章

  1. oracle学习笔记(四) DQL数据查询语言和TCL 事务控制语言

    DML 数据管理语言 Data manage language insert, update, delete以及select语句,不过,有人也把select单独出来,作为DQL 数据查询语言 data ...

  2. 一、TCL事务控制语言 二、MySQL中的约束 三、多表查询(重点) 四、用户的创建和授权 五、MySQL中的索引

    一.TCL事务控制语言###<1>事务的概念 事务是访问并可能更新数据库中各种数据项的执行单元. 事务是一条SQL语句,一组SQL语句,或者整个程序. 事务是恢复和并发控制的基本单位. 事 ...

  3. Oracle事务控制语言

    事务控制语言在各大数据库中都差不多,本文讲讲Oracle和别的数据库不一样的地方 Oracle每条sql语句都是一个事务,像insert.update.delete之类的,每次执行过都要commit提 ...

  4. <MySQL>入门四 事务控制语言 TCL

    -- TCL /* Transcation Control Language 事务控制语言 事务:一个或一组sql语句组成一个执行单元,这个执行单元要么全部执行,要么全部不执行 案例:转账 name ...

  5. MySQL数据库笔记三:数据查询语言(DQL)与事务控制语言(TCL)

    五.数据查询语言(DQL) (重中之重) 完整语法格式: select 表达式1|字段,.... [from 表名 where 条件] [group by 列名] [having 条件] [order ...

  6. oracle学习笔记(四) DML数据控制语言和TCL 事务控制语言

    DML 数据管理语言 Data manage language insert, update, delete以及select语句,不过,有人也把select单独出来,作为DQL 数据查询语言 data ...

  7. TCL(事务控制语言)

    #TCL/*Transaction Control Language 事务控制语言 事务:一个或一组sql语句组成一个执行单元,这个执行单元要么全部执行,要么全部不执行. 案例:转账 张三丰 1000 ...

  8. mysql事务控制语言TCL

    Transaction Control Language 事务控制语言 事务:一个或一组sql语句组成一个执行单元,这个执行单元作为不可分割的整体执行.如果某个语句执行错误,整个单元回滚到最初的状态. ...

  9. MySql——事务控制语言(DTL)

    什么是事务(控制台只能是内存的操作) 通常,在此之前,我们说,一条语句使用一个分号(;)来结束,并得到执行. 那么我们说,这个“一次性执行”的过程,可以称为“一个事务”. 简单来说,“一条sql语句, ...

随机推荐

  1. CF920F SUM and REPLACE 线段树

    给你一个数组a_i​,D(x)为x的约数个数 两种操作: 1.将[l,r]的a_i​替换为D(a_i) 2.输出∑​a_i ( l <= i <= r ) 当区间最大值<=2时,就不 ...

  2. hdu6062RXD and logic gates多校题 构造

    听说标算的点数是2^(n+1)级别的,也不知道我是不是比标算优一点? (话说这种题一眼看过去怎么跟题答一样) 然而并不是题答,没法手玩,来考虑一下一般解法: 考虑一个规模较小的问题:最后一位一定是0 ...

  3. 076 Minimum Window Substring 最小窗口子字符串

    给定一个字符串 S 和一个字符串 T,找到 S 中的最小窗口,它将包含复杂度为 O(n) 的 T 中的所有字符.示例:S = "ADOBECODEBANC"T = "AB ...

  4. 8.对于.NET的初步理解和介绍

    好久没写博客了,最近心情比较low,不知道为什么.很流行的一个问题叫做:如果你明天就挂了,那么你最后悔的事情将会是什么.我想了两个月,答案是不知道,无所谓.这样不好,那这个问题先放一边吧,我们开始这一 ...

  5. guacamole 0.9.13安装与配置

    以下命令很多都需要管理权限,建议使用管理员账号执行,遇到问题可以留言. Guacamole官网文档介绍翻译:http://www.cnblogs.com/ji-yun/p/5657709.html 1 ...

  6. 零基础逆向工程17_PE结构01_PE头解析_手动

    PE文件的两种状态 1.在硬盘中 节省硬盘空间 硬盘对齐 内存对齐 2.在内存中 3.PE磁盘文件与内存映像结构图 PE文件为什么要分节 -- 手动解析:PE文件 分析软件:飞鸽传书http://ww ...

  7. The Mythical Man-Month

    大家所熟知的Windows XP操作系统,源代码行数已经达到40百万行.为了连接用户和计算机底层硬件,庞大操作系统这一层太过于复杂,没有一个人能完全理解它如此数量的所有代码,而多人的合作开发又需要它被 ...

  8. freopen()函数

    freopen函数通过实现标准I/O重定向功能来访问文件,而fopen函数则通过文件I/O来访问文件. freopen函数在算法竞赛中常被使用.在算法竞赛中,参赛者的数据一般需要多次输入,而为避免重复 ...

  9. 火狐浏览器不支持location.reload()(以改变页面大小时重新刷新页面为例)

    背景:当页面大小改变时需要重新刷新页面,以适应相应的尺寸 解决方法: var url = window.location.href; var parm = parseInt(Math.random() ...

  10. BZOJ 4896 :[Thu Summer Camp2016]补退选 Trie树+Vector

    4896: [Thu Summer Camp2016]补退选 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 315  Solved: 97[Submi ...