事务控制语言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; 
五、事务的基本执行流程
- 事务声明开始:start transaction;
- 设定多条要执行的具体语句。比如,inesert,update,delete,...
- 其实只是“执行”,并不“‘生效’”--只是在内存状态下的执行,而不是在物理状态的执行
- 判断是否需要执行这些语句:
if(判断错误条件) {
//语句执行;
commit;//这时才生效--物理状态既写入硬盘
}
else {
rollback;//回滚--不执行任何语句
}
判断错误条件通常在以下2种环境:
- 命令行(cmd)环境,直接观察
- 如果是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的更多相关文章
- oracle学习笔记(四) DQL数据查询语言和TCL 事务控制语言
DML 数据管理语言 Data manage language insert, update, delete以及select语句,不过,有人也把select单独出来,作为DQL 数据查询语言 data ...
- 一、TCL事务控制语言 二、MySQL中的约束 三、多表查询(重点) 四、用户的创建和授权 五、MySQL中的索引
一.TCL事务控制语言###<1>事务的概念 事务是访问并可能更新数据库中各种数据项的执行单元. 事务是一条SQL语句,一组SQL语句,或者整个程序. 事务是恢复和并发控制的基本单位. 事 ...
- Oracle事务控制语言
事务控制语言在各大数据库中都差不多,本文讲讲Oracle和别的数据库不一样的地方 Oracle每条sql语句都是一个事务,像insert.update.delete之类的,每次执行过都要commit提 ...
- <MySQL>入门四 事务控制语言 TCL
-- TCL /* Transcation Control Language 事务控制语言 事务:一个或一组sql语句组成一个执行单元,这个执行单元要么全部执行,要么全部不执行 案例:转账 name ...
- MySQL数据库笔记三:数据查询语言(DQL)与事务控制语言(TCL)
五.数据查询语言(DQL) (重中之重) 完整语法格式: select 表达式1|字段,.... [from 表名 where 条件] [group by 列名] [having 条件] [order ...
- oracle学习笔记(四) DML数据控制语言和TCL 事务控制语言
DML 数据管理语言 Data manage language insert, update, delete以及select语句,不过,有人也把select单独出来,作为DQL 数据查询语言 data ...
- TCL(事务控制语言)
#TCL/*Transaction Control Language 事务控制语言 事务:一个或一组sql语句组成一个执行单元,这个执行单元要么全部执行,要么全部不执行. 案例:转账 张三丰 1000 ...
- mysql事务控制语言TCL
Transaction Control Language 事务控制语言 事务:一个或一组sql语句组成一个执行单元,这个执行单元作为不可分割的整体执行.如果某个语句执行错误,整个单元回滚到最初的状态. ...
- MySql——事务控制语言(DTL)
什么是事务(控制台只能是内存的操作) 通常,在此之前,我们说,一条语句使用一个分号(;)来结束,并得到执行. 那么我们说,这个“一次性执行”的过程,可以称为“一个事务”. 简单来说,“一条sql语句, ...
随机推荐
- puthon-进程间通信-队列和管道
********进程间通信-队列和管道******** ****进程间通信-队列和管道 IPC(Inter-Process Communication) ****队列 **概念介绍 创建贡献的进程队列 ...
- Django之Form组件归类
目录: Django内置字段 Django内置插件 常用选择插件 创建Form类时,主要涉及到 [字段] 和 [插件],字段用于对用户请求数据的验证,插件用于自动生成HTML; Field requi ...
- Ubuntu 下修改Tomcat和Jetty默认的JDK和初始内存
修改/etc/default/tomcat 或者 /etc/default/jetty 文件 中的 JAVA_HOME 和 JAVA_OPTS
- Redis hash(哈希)
Redis hash可储存多个键值对,适合储存对象的属性. 1.hset key fieldName fileValue //hset即hash set,set这里是设置的意思.往hash中添加 ...
- Java基础语法(数组)
第4天 Java基础语法 今日内容介绍 u 流程控制语句(switch) u 数组 第1章 流程控制语句 1.1 选择结构switch switch 条件语句也是一种很常用的选择语句,它和if条件语句 ...
- 解决Chrome浏览器自动记录用户名和密码的黄色背景问题和该解决方法与tab切换至下一个input冲突的问题。
哈哈哈,是不是标题很长呀,不逗你们了.其实这么长的标题主要就说了两件事: 第一件:解决Chrome浏览器自动记录用户名和密码的黄色背景问题. 第二件:输入完用户名后按下tab键切换至下一个输入密码in ...
- 准备Kendo UI 开发环境
准备 首先你需要从 Telerik 网站下载试用版开发包,注意需要注册后才能下载. 下载后直接解压后包含下面几个文件和目录: ./examples – 示例. /js – minified 化后的 J ...
- [20190611]记录一下github的基本用法
本文记录如何使用github创建项目并上传代码,因为有一段时间没用github了,中途又重装了系统,今天重新使用一下. 然后特地做简要记录: 1. 创建SSH Key SSH Key指一般在C:\Us ...
- File类--System.out.print(Object obj)的理解
一.File 类(java.io) 概述:Java中使用File类来表示文件或者文件夹对象! 抽象路径名:描述文件或文件夹时,使用的路径符号,就是一个对象的字符串表示形式,如"c:\ ...
- 帝国empirecms后台登陆次数限制修改
打开文件:\e\config\config.php, 找到 'loginnum'=>5, 把5改为自己想要的数字即可