彻底搞懂mysql隔离级别和事务

本文详细探讨了MySQL的事务隔离级别,包括READ UNCOMMITTED(未提交读)、READ COMMITTED(提交读)、REPEATABLE READ(可重复读)和SERIALIZABLE(可串行化)。通过实例演示了不同隔离级别下,INSERT、UPDATE、SELECT和DELETE操作的行为,展示了各种并发问题如脏读、幻读和不可重复读。
摘要由CSDN通过智能技术生成

前言

       我们都知道,mysql的InnoDB存储引擎支持事务操作,事务ACID特性中的隔离性可以使当前事务中的操作不受其他事务操作的影响,然而,这个隔离性是和隔离级别相关的特性,不同的隔离级别对隔离的严格性不同,对不同的隔离级别一一实验后,我们会发现,如果单单说事务的隔离性不受其他事务的影响,这句话是不太准确的,或者说是不严谨的说法。作为一个工科,我觉得能看到一个示例,比单纯看理论更能让人理解、记忆深刻。

一、查看和设置当前的隔离级别:      

我们先登录mysql终端,查看和设置当前的隔离级别:

mysql> show variables like '%isolation%';

+---------------+-----------------+

| Variable_name | Value           |

+---------------+-----------------+

| tx_isolation  | REPEATABLE-READ |          //mysql默认的是RR的隔离级别

+---------------+-----------------+

1 row in set (0.00 sec)

 

或者执行以下命令:

mysql> select @@global.tx_isolation, @@tx_isolation;

+-----------------------+-----------------+

| @@global.tx_isolation | @@tx_isolation  |

+-----------------------+-----------------+

| REPEATABLE-READ       | REPEATABLE-READ |

+-----------------------+-----------------+

1 row in set (0.00 sec)

 

 

// 修改事务隔离级别:

可以  help ISOLATION 查看一下都有哪些隔离级别,或者直接

set session transaction isolation level 事务隔离级别,如设置成RU隔离级别:

set session transaction isolation level READ UNCOMMITTED;

 <

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值