MySQL-事务

事务是一组操作的集合,他是一个不可分割的工作单位,事务会把所有的操作作为一个整体一起向系统提交或撤销操作请求,这些操作要么同时成功,要么同时失败。

举个例子:张三要给李四转1000块钱,需要做的事有三件:1.查询张三账户余额。2.张三账户余额-1000。 3.李四账户余额加1000。这三件事要么同时成功,要么同时失败。

所以我们首先得在操作之前开启事务。操作完成后再提交事务。当代码中间抛出异常,我们可以回滚事务回到最初状态。

注意:

1.默认MySQL的事务事自动提交的,也就是说,当执行一条DML语句,MySQL会立即隐式的提交事务。

2.只有提交事务后表的内容才会真实刷新。

事务操作:

查看/设置事务提交方式

SELECT @@autocommit;

事务开启方式一: SET @@autocommit=0;//如果为1事自动提交,为0为手动提交。

事务开启方式二: START TRANSACTION;// 开启事务。

提交事务

COMMIT;

回滚事务

ROLBACK;

事务四大特性

**原子性:**事务是不可分隔的最小操作单元,要么全部成功,要么全部失败。

**一致性:**事务完成时,必须使所有数据都保持一致状态。

**隔离性:**数据库系统提供的隔离机制,保证事务在不受外部并发操作的独立环境下运行。

**持久性:**事务一旦提交或回滚,他对数据库中的数据的改变就是永久的。

并发事务问题:

**脏读:**一个事务读到另一个事务还没有提交的数据

演示:

我们首先打开两个命令行模拟两个客户端。登入一个账户:

数据库中有一张表,我们使用客户端1进行查询。

客户端2开启一个事务:

客户端2修改数据,并未提交事务:

客户端一再次查询:发现数据已经更改

**不可重复读:**一个事务先后读取同一条记录,但两次读取的数据不同,称之为不可重复读

客户端一,客户端二同时开启一个事务

客户端一进行数据查询

客户端二进行数据修改并提交事务

客户一再次查询:发现数据变更

**幻读:**一个事务按照条件查询时,但没有对应的数据行,但是在插入数据时,发现这行数据已经存在,好像出现了幻影。

客户端一,客户端二同时开启一个事务

客户端进行查询:查询记录没有结果

客户端2插入数据:

客户端二事务提交

客户端一插入数据:发现报错

客户端一再次查询数据:发现还是没有数据

事务隔离级别:能解决并发事务问题

从上至下性能逐渐降低,但安全性逐渐增强。

查看事务隔离级别:

SELECT @@TRANSACTION_ISOLATION;

设置事务隔离级别:

SET [SESSION | GLOBAL] TRANSACTION ISOLATION LEVEL 隔离级别;

注意:SESSION表示会话级别,表示仅对于当前客户端窗口有效。GLOBAL表示仅对于所有客户端窗口有效。

相关推荐
阿华的代码王国10 分钟前
MySQL ------- 索引(B树B+树)
数据库·mysql
Hello.Reader38 分钟前
StarRocks实时分析数据库的基础与应用
大数据·数据库
执键行天涯40 分钟前
【经验帖】JAVA中同方法,两次调用Mybatis,一次更新,一次查询,同一事务,第一次修改对第二次的可见性如何
java·数据库·mybatis
liupenglove1 小时前
golang操作mysql利器-gorm
mysql·golang
yanglamei19621 小时前
基于GIKT深度知识追踪模型的习题推荐系统源代码+数据库+使用说明,后端采用flask,前端采用vue
前端·数据库·flask
叫我:松哥1 小时前
基于Python flask的医院管理学院,医生能够增加/删除/修改/删除病人的数据信息,有可视化分析
javascript·后端·python·mysql·信息可视化·flask·bootstrap
工作中的程序员1 小时前
ES 索引或索引模板
大数据·数据库·elasticsearch
严格格1 小时前
三范式,面试重点
数据库·面试·职场和发展
微刻时光2 小时前
Redis集群知识及实战
数据库·redis·笔记·学习·程序人生·缓存
单字叶2 小时前
MySQL数据库
数据库·mysql