18 TCL 事务控制语言和事务并发 --- sql --- 初学者

作者:Irain
QQ:2573396010
微信:18802080892
Github文件:18 TCL 事务控制语言 和事务并发 -
视频链接:TCL 事务控制语言和事务并发 -
软件环境:MySQL Front

一、TCL 事务控制语言

1 事务 Transaction Control Language

含义:一个或一组sql语句注册一个执行单元,这个执行单元要么全部执行,要么全部不执行
特性:原子性、一致性、隔离性、持久性(ACID)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2 事务的创建

隐式事务:事务没有明显的开启和结束的标记
比如:insert、update、delete语句
显式事务:事务有明显的开启和结束的标记
前提:必须先设置自动提交功能为禁用
set autocommit = 0; # 关闭自动提交,当前会话有效
显式事务步骤:
步骤1:set autocommit = 0; 或 start transaction;可选
步骤2:编写事务中的sql语句(select、inset、update、delete)
步骤3:结束事务。commit:提交事务; rollback:回滚事务。

#  创建表
drop table if exists tab;
create table if not exists tab(
    id int,
    varname varchar(10)
);
2.1 成功提交事务
set autocommit = 0;
start transaction;
insert into tab values(1,'aa');#  编写一组事务的语句
insert into tab values(2,'bb');
commit; # 结束事务
select * from tab;

在这里插入图片描述

2.2 回滚事务
set autocommit = 0;
start transaction;
insert into tab values(3,'cc');#  编写一组事务的语句
insert into tab values(4,'dd');
rollback; # 回滚事务
select * from tab;

在这里插入图片描述

2.3 savepoint与rollback搭配
select * from tab;
set autocommit=0;
start transaction;  # 开启事务
delete from tab where id=3;  # 成功删除id=3的数据
savepoint id1;  # rollback回滚到位置,仍然执行删除id=3数据的指令
delete from tab where id=4;  # 因为rollback回滚,没有删除id=4的数据
rollback to id1;  # 回滚到savepoint节点位置。rollback与savepoint之间的执行无效
select * from tab;

在这里插入图片描述
在这里插入图片描述

2.4 delete与truncate在事务的作用
2.4.1 delete删除操作,无效
set autocommit=0;
start transaction;  # 开启事务
delete from tab;
rollback;
select * from tab;

在这里插入图片描述

2.4.2 truncate删除操作,有效
set autocommit=0;
start transaction;  # 开启事务
truncate table tab;
rollback;
select * from tab;

在这里插入图片描述

二、事务并发

1 事务并发问题介绍

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2 事务的隔离级别演示

在这里插入图片描述

2.1 查看当前事务的隔离级别

在这里插入图片描述

2.2 设置当前事务隔离级别为read uncommitted,出现脏数据、不可重复读、幻读的并发问题

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

2.3 事务隔离级别read committed,出现不可重复读、幻读的并发问题

在这里插入图片描述

2.3 事务隔离级别repeatable read ,出现幻读的并发问题

在这里插入图片描述

插入/删除操作会出现幻读

在这里插入图片描述

2.4 事务隔离级别:serializable、最高级别,避免所有并发问题

在这里插入图片描述
在这里插入图片描述

发布:2020年4月28日

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这本教程花费了我足足两个月的时间写的,每个章节以例子为核心讲解知识点,最大的好处是要用的时候把代码粘贴一下,修改修改就可以上手用了,绝对原创,光是调试这些例子就够我折腾了。知识点覆盖比较全面,要个20分不过分吧,有几本书认真讲过那些常用模块: socket, 数据库操作,xml解析,多线程,最具体的做法多半是一带而过,我可是一个例子一个例子做出来的。 把目录发给大家看看: 2.1 第1课:简单文本输出 5 2.2 第2课:给变量赋值 5 2.3 第3课:命令的赋值与置换一 6 2.4 第4课:命令的赋值与置换二 7 2.5 第5课:命令的赋值与置换三 7 2.6 第6课:算数运算 8 2.7 第7课:文本比较-SWITCH应用 9 2.8 第8课:数值比较-IF应用 10 2.9 第9课:WHILE 循环 11 2.10 第10课:FOR循环和INCR 11 2.11 第11课:过程PROC 12 2.12 第12课:过程PROC的参数定义 13 2.13 第13课:变量的作用域 13 2.14 第14课:LIST结构 14 2.15 第15课:LIST项的增删改 15 2.16 第16课:更多LIST相关 16 2.17 第17课:字符串函数 17 2.1818课:更多字符串函数 17 2.19 第19课:修改字符串函数 20 2.20 第20课:正则表达式 21 2.21 第21课:更多正则表达式 22 2.22 第22课:数组 24 2.23 第23课:更多数组相关 25 2.24 第24课:文件存取 28 2.25 第25课:文件信息 30 2.26 第26课:TCL中的子进程调用-OPEN & EXEC 33 2.27 第27课:命令或者变量是否存在-INFO 34 2.28 第28课:解释器状态-INFO 35 2.29 第29课:过程信息-INFO 36 2.30 第30课:模块化-SOURCE 37 2.31 第31课:建库-UNKNOWN & INFO LIBRARY 38 2.32 第32课:创建命令-EVAL 40 2.33 第33课:在EVAL中应用FORMAT & LIST 40 2.34 第34课:不使用EVAL替换-FORMAT & SUBST 42 2.35 第35课:改变工作目录- CD & PWD 43 2.36 第36课:调试和错误-ERRORINFO & ERRORCODE & CATCH 44 2.37 第37课:调试-TRACE 45 2.38 第38课:命令行参数和环境串 46 2.39 第39课:TIME & UNSET 47 2.40 第40课:SOCKET & FILEEVENT & VWAIT 49 2.41 第41课:日期时间-CLOCK 51 2.42 第42课:I/O通道-FBLOCKED & FCONFIG 53 2.43 第43课:子解释器 56 2.44 第44课:数据库操作 57 2.45 第45课:函数或过程数组的输入和输出方法 59 2.46 第46课:INFO的用法 60 2.47 第47课:多线程 61 2.48 第48课:解析XML 72

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值