MySQL事务隔离

MySQL 事务

MySQL 事务都是指在 InnoDB 引擎下,MyISAM 引擎是不支持事务的。

数据库事务指的是一组数据操作,事务内的操作要么就是全部成功,要么就是全部失败。

事务具有原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)四个特性,简称 ACID。

MySQL事务相关概念

脏读

指的是读到了其他事务未提交的数据,未提交意味着这些数据可能会回滚。读到了并一定最终存在的数据,这就是脏读。

可重复读

指的是在一个事务内,最开始读到的数据和事务结束前的任意时刻读到的同一批数据都是一致的。通常针对数据更新(UPDATE)操作。

不可重复读

指的是在同一事务内,不同的时刻读到的同一批数据可能是不一样的,可能会受到其他事务的影响,比如其他事务改了这批数据并提交了。通常针对数据更新(UPDATE)操作。

幻读

针对数据插入(INSERT)操作来说的。假设事务A对某些行的内容作了更改,但是还未提交,此时事务B插入了与事务A更改前的记录相同的记录行,并且在事务A提交之前先提交了,而这时,在事务A中查询,会发现好像刚刚的更改对于某些数据未起作用,但其实是事务B刚插入进来的,让用户感觉很魔幻,感觉出现了幻觉,这就叫幻读。

MySQL事务隔离级别

SQL 标准定义了四种隔离级别,MySQL 全都支持。这四种隔离级别分别是:

  1. 读未提交(READ UNCOMMITTED)
  2. 读提交 (READ COMMITTED)
  3. 可重复读 (REPEATABLE READ)
  4. 串行化 (SERIALIZABLE)

MySQL事务相关sql

-- 查看事务级别
-- 查看全局事务级别 show global variables like 'transaction_isolation'; select @@transaction_isolation;
-- 查看当前会话事务级别
select @@global.transaction_isolation;
-- 查询设置脏读 set session transaction isolation level read uncommitted; select * from table_name; set session transaction isolation level repeatable read; -- 全局设置脏读 set global transaction isolation level read uncommitted;

 

posted @ 2023-04-13 21:24  林远  阅读(24)  评论(0)    收藏  举报