MYSQL 事务

1、事务

什么叫事务?

事务就是将一组工作看做一个整体去完成,要么同时成功,要么同时失败,并且遵守ACID事务四大特性。

2、事务操作

1、查看事务提交状态

SELECT @@autocommit;

2、设置事务的提交方式,0为手动,1为自动

SET @@autocommit=0;

3、提交事务

COMMIT

4、回滚事务

ROLLBACK

5、手动开启事务

START TRANSACTION 或 BEGIN

手动开启事务就必须手动提交事务,默认事务是自动开启的,设置事务的提交方式是手动需要手动提交。

3、事务的四大特性ACID

原子性(Atomicity)、一致性(Consistant)、隔离性(Isolation)、持久性(Durability)

原子性:每个事务可操作的最小单位。

一致性:事物之间操作前后应该保持一致

隔离性:事务直接操作不应该互相影响

持久性:数据库操作后放入硬盘中,保持持久

4、并发事务问题

脏读:一个事务读取到另一个事务还没有提交的数据,没有提交说明改事务还没结束。

不可重复读:两次读取同一个数据发生结果不一致的结果,因为第二次读取事务之前,别的事务将该条数据修改提交了,所以读取到的数据前后不一致。

幻读:一个事物读取id=1的某条数据,查询结果显示没有该条数据,此时插入id=1的的数据发生插入失败,感觉到好像有此条数据,是事务A进行查询的时候B事务进行插入,此时查是查不到的。

5、解决并发实物问题(MYSQL默认是可重复读)

|------------|----|-------|----|
| 隔离级别解决对应事务 | 脏读 | 不可重复读 | 幻读 |
| 读未提交 | × | × | × |
| 读已提交 | √ | × | × |
| 可重复读 | √ | √ | × |
| 串行化 | √ | √ | √ |

1、查看事务隔离级别

SELECT @@TRANSACTION_ISOLATION;

2、设置事务隔离界别

SELECT [SESSION|GLOBAL] TRANSACTION ISOLATION LEVEL {READ UNCOMMITTED|READ COMMITTED|REPEATABLE READ|SERIALIZABLE}

SERIALIZABLE串行化的实物隔离级别开启后只有别的事务结束了才能继续进行,也就是说事务的隔离级别越高,并发性能越差,但是越安全。

相关推荐
韩立学长8 小时前
【开题答辩实录分享】以《自助游网站的设计与实现》为例进行选题答辩实录分享
java·mysql·spring
SAP小崔说事儿8 小时前
在数据库中将字符串拆分成表单(SQL和HANA版本)
java·数据库·sql·sap·hana·字符串拆分·无锡sap
川贝枇杷膏cbppg9 小时前
asmcmd
数据库·oracle
JIngJaneIL10 小时前
基于java+ vue助农电商系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
q_191328469510 小时前
基于Springboot+MySQL+RuoYi的会议室预约管理系统
java·vue.js·spring boot·后端·mysql·若依·计算机毕业设计
IndulgeCui10 小时前
基于CentOS7 DM8单机部署配置记录-20251216
数据库
surtr110 小时前
关系代数与关系型数据库
数据库·sql·数据库系统
学海_无涯_苦作舟10 小时前
MySQL面试题
数据库·mysql·面试
老邓计算机毕设11 小时前
SSM校内二手书籍交易系统的设计与实现an1k0(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·ssm 框架开发·ssm 校内二手书籍交易系统
天行健,君子而铎11 小时前
高性能、可控、多架构:教育行业数据库风险监测一体化解决方案
数据库·架构