事务控制语言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;//回滚到最初状态

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

  结果:

  还钱:结果:

原文地址:https://www.cnblogs.com/gaogzhen/p/10015357.html

时间: 2024-10-13 20:21:39

事务控制语言DTL的相关文章

TCL_事务控制语言

TCL     transaction  事务   --  DML            定义为把一连串的操作作为单个逻辑工作单元处理                -----     例如:银行转账 事务特性   ACID     原子性     atomicity           所有的数据修改  要么一起执行  要么不执行     一致性     congsistency     所有的数据修改同时得到反应     隔离性     isolation             另一个事务

数据库---数据控制语言(DCL)

数据控制,其实就是"分配权限"--就涉及到用户.则主要就是2个问题: 用户管理: 权限分配: 有哪些权限.mysql中的权限mysql中,权限是系统内定的一些"名词"(单词),大约30个,每个权限表示"可以做什么工作". 则分配权限就是相当于让某个用户可以做哪些工作.主要权限如下: mysql中的用户:mysql中的用户信息都存储在系统数据库mysql的user表中.创建用户语法形式: create user '用户名'@'允许其登录的地址' i

mysql----事务控制语言--TCL

TCL:事务控制语言 事务:一个或者一组sql语句组成的一个执行单元,这个执行单元,要么都执行要么都不执行 案例;转账 张三丰 1000 郭襄 1000 场景,张三丰给郭襄转账500块钱 update 表 set 张三丰的余额=500 where name='张三丰'; update 表 set 郭襄的余额=1500 where name='郭襄'; 事务的特性ACID 这是必须要记住的 show ENGINES 事务的创建: 隐式事务:事务没有明显的开启或者结束的标记 比如,之前学习过的ins

oracle中如何更改一个表的一个字段属性(名称,类型)

修改字段的属性,名称方法 --修改某一个字段的类型,当该字段不为null时 ALTER TABLE 表名 ADD  字段 NUMBER(11,0) ; --新创建一列,期待的字段类型 UPDATE 表名 SET 字段_bak= 字段;COMMIT; --复制旧字段值到新字段,dml的都需要提交 ALTER TABLE 表名DROP COLUMN 字段;--删除掉旧字段 ALTER TABLE 表名RENAME COLUMN 字段_bakTO 字段;--修改新字段的名称 alter table 表

Oracle数据库语句大全

转自:http://blog.sina.com.cn/s/blog_b5d14e2a0101c56z.html ORACLE支持五种类型的完整性约束 NOT NULL (非空)--防止NULL值进入指定的列,在单列基础上定义,默认情况下,ORACLE允许在任何列中有NULL值. CHECK (检查)--检查在约束中指定的条件是否得到了满足. UNIQUE (唯一)--保证在指定的列中没有重复值.在该表中每一个值或者每一组值都将是唯一的. PRIMARY KEY (主键)--用来唯一的标识出表的每

oracle概念

01.DDL 数据定义语言 create alter drop truncate 02.DML 数据操作语言 insert delete update select 03.TCL 事务控制语言 commit rollback 04.DCL 数据控制语言 rovoke grant sql分类 A(Atomicity):原子性 一个事务是一个不个分割的工作单位,要么所有的语句都执行成功, 要么所有的语句都不执行. C(Consistency):一致性 事务必须是是一个数据库从一个一致性状态变到另一个

SQL中的四种语言DDL,DML,DCL,TCL

1.DDL(Data Definition Language)数据库定义语言statements are used to define the database structure or schema. DDL是SQL语言的四大功能之一.用于定义数据库的三级结构,包括外模式.概念模式.内模式及其相互之间的映像,定义数据的完整性.安全控制等约束DDL不需要commit.CREATEALTERDROPTRUNCATECOMMENTRENAME 2.DML(Data Manipulation Lang

mysql学习笔记(三)--- 基本的SQL语句

[正文] 主要内容: 一.cmd命令行的常用命令 二.数据定义语言(DDL) 三.数据操纵语言(DML) 四.数据查询语言(DRL) 五.事务控制语言(TCL) 一.cmd命令行的常用命令: 当我们使用MySQL 5.5 Command Line Client这个客户端登陆时,只能登陆root用户.如果今后创建了别的用户,就很麻烦了,所以我们不用MySQL 5.5 Command Line Client这个客户端,而是直接使用cmd. 登录MySQL数据库: 因为在这之前安装MySQL的时候,已

Oracle第三章——SQL语言

SQL语言是高级的结构化查询语言,大大减轻了用户的负担.目前查询语言分为四种,数据定义语言(DDL).数据操纵语言(DML). 事务控制语言(TCL).数据控制语言(DCL). 一.数据定义语言(DDL) 1.CREATE CREATE命令用于创建模式对象,如创建表的格式为:CREATE TABLE [schema.]table (column datatype [, column datatype]);,其中, schema是对象的持有者,即用户对应的模式,如果在用户自己的模式中创建则可以不指