码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • MySQL事务


    目录

        • 1. MySQL 事务的四大特性
            • 一、原子性(Atomicity ):
            • 二、一致性(Consistency ):
            • 三、隔离性(Isolution ):
            • 四、持久性(Durability ):
        • 2. MySQL 事务的并发问题
            • 一、脏写
            • 二、脏读
            • 三、不可重复读
            • 四、幻读
        • 3. MySQL 事务的隔离级别
            • 一、读未提交(read uncommitted)
            • 二、读已提交(read committed)
            • 三、可重复读(repeatable read)
            • 四、可串行化(serializable)
        • 4. MySQL 隔离级别查看、设置、验证
            • 一、查看事务隔离级别
            • 二、设置事务隔离级别
            • 三、验证事务隔离级别
              • ①、验证读已提交隔离级别
              • ②、验证其他隔离级别

    1. MySQL 事务的四大特性

    MySQL 事务具有四个特性:原子性、一致性、隔离性、持久性,这四个特性简称 ACID 特性。

    一、原子性(Atomicity ):

    一个事务是一个不可再分割的整体,要么全部成功,要么全部失败。

    二、一致性(Consistency ):

    一个事务可以让数据从一种一致状态切换到另一种一致性状态。

    三、隔离性(Isolution ):

    一个事务不受其他事务的影响,并且多个事务彼此隔离。

    四、持久性(Durability ):

    一个事务一旦被提交,在数据库中的改变就是永久的,提交后就不能再回滚。

    2. MySQL 事务的并发问题

    事务并发问题指的是多个事务同时操作同一数据库的同一个表时,出现的问题。

    要产生问题,事务里语句执行的顺序是关键,两个事务在时间上的先后顺序。

    一、脏写

     ①事务A开启事务,事务B开启事务(开启事务先后顺序无影响)
     ②事务A更改person表,字段A内容
     ③事务B更改Person表,字段A内容
     ④事务B提交内容
     ⑤事务A回滚

    二、脏读

     ①事务A开启事务,事务B开启事务(开启事务先后顺序无影响)
     ②事务A更改person表,字段A内容
     ③事务B读取Person表,字段A内容
     ④事务A回滚

    三、不可重复读

     ①事务A开启事务,事务B开启事务(开启事务先后顺序无影响)
     ②事务A更改person表,字段A内容 ,并提交事务
     ③事务B读取Person表,字段A内容
     ④事务A开启事务,在此更改person表,字段A内容 ,并提交事务
     ⑤事务B读取Person表,字段A内容

    四、幻读

     ①事务A开启事务,事务B开启事务(开启事务先后顺序无影响)
     ②事务A插入到person表一条数据 ,并提交事务
     ③事务B读取Person表所有数据
     ④事务A开启事务,在此插入person表一条数据 ,并提交事务
     ⑤事务B读取Person表所有数据

    3. MySQL 事务的隔离级别

      事务隔离级别是针对事务特性的隔离性来说的,隔离级别高可以解决事务的一些并发问题,但是会造成性能下降。

    一、读未提交(read uncommitted)
    二、读已提交(read committed)
    三、可重复读(repeatable read)
    四、可串行化(serializable)

    4. MySQL 隔离级别查看、设置、验证

    一、查看事务隔离级别
    # 查看全局事务隔离级别
    select @@global.tx_isolation;
    
    # 查看会话事务隔离级别(也就是当前窗口)
    select @@tx_isolation;
    select @@transaction_isolation;
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    二、设置事务隔离级别
    #将session改成global就变成全局的事务隔离级别,也就是MySQL服务不重启,会一直保持该设置的隔离级别不变。
    #session是当前会话的隔离级别,也就是当前窗口
    # 读未提交  
    set session transaction isolation level read uncommitted;
    # 读已提交
    set session transaction isolation level read committed;
    # 可重复读(默认隔离级别)
    set session transaction isolation level repeatable read;
    # 可串行化
    set session transaction isolation level serializable;
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    三、验证事务隔离级别

    要想验证事务的隔离级别,就需要知道设置成该隔离级别解决了什么问题,不同隔离级别解决的问题如下图所示:
    在这里插入图片描述

    ①、验证读已提交隔离级别

    读已提交的隔离级别解决了脏读的问题,第一步就要复现脏读,将隔离级别设置为读未提交,因为读未提交未解决脏读问题,第二步,将隔离级别设置为读已提交,看看脏读问题是否得到解决。

    (1)开启两个查询窗户,分别将起隔离级别设置为读未提交。
    在这里插入图片描述
    (2)事务A开启事务,并更新person表中name字段内容

    person表初始数据如下图:
    在这里插入图片描述

    在这里插入图片描述

    (3)事务B开启事务,并查询person表id为2的数据
    在这里插入图片描述

    查询结果
    在这里插入图片描述

    (4)再将事务A回滚

    在这里插入图片描述

    (5)事务B再次查询person表
    在这里插入图片描述
    查询结果如下:
    在这里插入图片描述
    可以看到一个现象,对于事务A更改表后回滚的操作,事务B读取到了不同的值,这就是脏读。

    (6)更改这两个窗口的事务隔离级别为读已提交,在进行 (2) - (5) 的观察

    这时会发现对于未提交的事务A,无论怎么更改表中数据,事务B都不会查询出不一样的结果,这就是读已提交解决的脏读问题。

    ②、验证其他隔离级别

    按照①的思路,去验证其他隔离级别即可。

  • 相关阅读:
    使用Spring Boot向邮箱发送邮件
    教你怎么把视频转换成gif动图
    【计算机视觉】图像增强——图像的形态学操作
    启山智软/多商户商城源码优势
    ssm电商背景下精品茶网站的设计与实现毕业设计-附源码191732
    视频监控系统/视频汇聚平台EasyCVR有下级平台注册时出现断流情况该如何排查解决?
    Redis企业级问题及解决方案
    mybatis单框架通用mapper使用(二)
    深入浅出:SPI机制在JDK与Spring Boot中的应用
    从面试官角度分析:面试功能测试工程师主要考察哪些能力?
  • 原文地址:https://blog.csdn.net/PhilsphyPrgram/article/details/126890503
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号