MySQL TCL操作(数据库事务基础)

本文详细解析MySQL中事务的四大特性:原子性、一致性、隔离性和持久性,以及事务自动提交机制。深入探讨并发事务可能引发的问题,如脏读、不可重复读和幻读,并介绍四种事务隔离级别的特点与解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一.事务的四大特性

事务:

由一组DML操作组成,要么同时成功,要么同时失败。

.MySQL默认的开启事务自动提交(autocommit)

MySQL默认将每个DML看作是独立的事务

1.原子性

 整体操作不可分割

2.一致性

事务执行前后整体状态不变。

3.隔离性

并发事务之间不能产生干扰。

4.持久性

事务提交之后数据将持久化存储。

事务自动提交:

-- 查看是否开启了数据库事务 
show variables like '%autocommit%';

-- 关闭事务自动提交
set autocommit=0;

-- 开启事务 
start transaction/begin;

-- 提交事务 
commit;

--事务回滚
rollback;

二.并发事务产生的问题

脏读: t1读到t2未提交的数据。
不可重复读: t1在多次读取范围内读到数据不一致问题。原因:t2在t1读取间隔内对数据进行修改并
	提交了事务。
幻读(虚读): t1在多次操作读取范围内发现数据不一致问题。 原因:t2在操作范围内,由t1对数据
	进行增删等操作,导致t2发现操作未完成,出现数据增加或减少。	

三.事务的隔离级别

1.读未提交

 即读到别人还没有进行提交的数据,即会产生脏读,不可重复读和幻读
 解决方案:无法解决 (不设置)

2.读已提交

会产生不可重复读和幻读
解决脏读问题 (Oracle默认使用,对于不可重复读的解决方案是undo)

3.可重复读

会产生幻读
解决脏读和不可重复读(MySQL默认)

4.串行化

解决所有问题,但是相对来说效率是最低的。

查看事务的隔离级别:

select @@tx_isolation; 

设置事务提交隔离级别:

 set  [glogal | session]  transaction isolation level 隔离级别名称;
 
 事务隔离级别名称:
 	Serializable (串行化)
	Repeatable read (可重复读)
	Read committed (读已提交)
	Read uncommitted (读未提交) 
这本教程花费了我足足两个月的时间写的,每个章节以例子为核心讲解知识点,最大的好处是要用的时候把代码粘贴一下,修改修改就可以上手用了,绝对原创,光是调试这些例子就够我折腾了。知识点覆盖比较全面,要个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.18 第18课:更多字符串函数 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、付费专栏及课程。

余额充值