实用 | 数据库(MySQL)事务详解

10 篇文章 0 订阅

数据库事务详解

一、事务的概念

概念:
如果一个包含多个(二个或以上)步骤的业务操作,被事务管理,那么这些操作要么同时成功,要么同时失败。
操作:
1. 开启事务: start transaction;
2. 回滚:rollback;//就回到了事务开启的地方
3. 提交:commit;//真正将事务开启到事务提交的所有内容,真正更新到表中

CREATE TABLE account (
			id INT PRIMARY KEY AUTO_INCREMENT,
			NAME VARCHAR(10),
			balance DOUBLE
		);

– 添加数据:

INSERT INTO account (NAME, balance) VALUES ('zhangsan', 1000), ('lisi', 1000);
		SELECT * FROM account;
		UPDATE account SET balance = 1000;

例子:张三给李四转账 500 元,步骤如下:

        -- 0. 开启事务
		START TRANSACTION;
		
		-- 1. 张三账户 -500
		UPDATE account SET balance = balance - 500 WHERE NAME = 'zhangsan';
		
		-- 2. 李四账户 +500
		-- 出错了...
		UPDATE account SET balance = balance + 500 WHERE NAME = 'lisi';
		
		-- 发现执行没有问题,提交事务
		COMMIT;
		
		-- 发现出问题了,回滚事务
		ROLLBACK;

二、事务_默认自动提交&手动提交

事务提交的两种方式:
1.自动提交:
* mysql数据库默认是自动提交。
* 一条DML(增删改)语句会自动提交一次事务。
//开始事务 start transaction
insert into …
//如果上述语句正确,自动提交 commit
//MySQL会将缓存中的结果,同步到硬盘中的MySQL文件中

请问,那DDL语句,会有事务吗?
DDL语句一旦执行正确,就提交了,不能回滚
2.手动提交:
* Oracle 数据库默认是手动提交事务
* 需要先开启事务,再提交

修改事务的默认提交方式:
1.查看事务的默认提交方式:
SELECT @@autocommit;
1 代表自动提交 0 代表手动提交
2.修改默认提交方式:
set @@autocommit = 0;
别忘了,还得改回来自动提交

三、事务四大特征

事务的四大特征:
1. 原子性A:是不可分割的最小操作单位,要么同时成功,要么同时失败。
2. 持久性D:当事务提交或回滚后,数据库会持久化的保存数据。
3. 隔离性I:多个事务之间,要相互独立。
4. 一致性C:事务操作前后,数据总量不变,例如转帐前后总量相同。

CURD-增删改查
ACID-原子性/一致性/隔离性/持久性

四、事务隔离级别介绍

事务隔离级别:
多个事务之间隔离的,是相互独立的。
但是如果多个事务操作同一批数据,则会引发一些问题,设置不同的隔离级别就可以解决这些问题。
存在问题:
1. 脏读:一个事务,读取到另一个事务中没有提交的数据。(MySQL支持)
2. 不可重复读(虚读):在同一个事务中,两次读取到的数据不一样。(MySQL支持)
3. 幻读:一个事务操作(DML)数据表中所有记录,另一个事务添加了一条数据,则第一个事务查询不到自己的修改。

隔离级别:
1. read uncommitted:读未提交
* 产生的问题:脏读、不可重复读、幻读
2. read committed:读已提交 (Oracle默认)
* 产生的问题:不可重复读、幻读
3. repeatable read:可重复读 (MySQL默认)
* 产生的问题:幻读
4. serializable:串行化
* 理解为对表加锁
* 可以解决所有的问题
注意:
隔离级别从小到大安全性越来越高,但是效率越来越低
设置完隔离级别后,重新打开新的控制台,这样才生效。

五、事务隔离级别演示1

数据库查询隔离级别:
	* select @@tx_isolation;
数据库设置隔离级别:
	* set global transaction isolation level 级别字符串;
    * 设置新的隔离级别后,要重新启动MySQL客户端工具,才会生效。
采用二个控制台窗口演示:
	set global transaction isolation level read uncommitted;
	start transaction;
	-- 转账操作
	update account set balance = balance - 500 where id = 1;
	update account set balance = balance + 500 where id = 2;

六、事务隔离级别演示2

数据库查询隔离级别:
	* select @@tx_isolation;
数据库设置隔离级别:
	* set global transaction isolation level 级别字符串;
采用二个控制台窗口演示:
	set global transaction isolation level read uncommitted;
	start transaction;
	-- 转账操作
	update account set balance = balance - 500 where id = 1;
	update account set balance = balance + 500 where id = 2;

在这里插入图片描述

如果左边窗口一直没有提交/回滚事务,那么只要MySQL的事务超时时间到了,MySQL自动回滚事务,这时右边窗口就可以操作数据了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值