码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • [mysql] 深入分析MySQL版本控制MVCC规则--实测 (mysql 8.0 innodb引擎)


    背景:基于之前的一篇文章

     可重复读:可重复读隔离级别的实现是每个事务在打开时都会生成一个一致的视图。 当其他事务提交时,不会影响当前事务中的数据。 为了保证这一点,MySQL是通过多版本控制机制MVCC来实现的; 我们亲自验证下;[mysql] 深入分析MySQL版本控制MVCC规则_平静不绝望的博客-CSDN博客_mysql版本控制

    1 事务隔离级别查看 (RR级别)

    2 事务1开始:左边窗口客户端(START TRANSACTION;)

     3. 事务1 执行select * from  posts  where id = 1; 快照查看 post_id = 2;事务2右侧窗口开启START TRANSACTION; 并update post_id = 2000;

    4.  事务1 执行select * from  posts  where id = 1; 快照查看 post_id = 2 (快照不变)

         事务2 执行select * from  posts  where id = 1; 快照查看 post_id = 2000

     5. 事务2 提交事务 commit;

         事务1 执行select * from  posts  where id = 1; 快照查看 post_id = 2 (快照不变)     

     6. 事务1 提交事务 commit; 再执行查询post_id = 2000; 内容改变

     7. 结论: 

       mysql RR级别下,MVCC实现了多版本快照读;

    8. 参考命令

    1. mysql> SELECT @@GLOBAL.tx_isolation, @@tx_isolation;
    2. +-----------------------+-----------------+
    3. | @@GLOBAL.tx_isolation | @@tx_isolation |
    4. +-----------------------+-----------------+
    5. | REPEATABLE-READ | REPEATABLE-READ |
    6. +-----------------------+-----------------+
    7. 1 row in set (0.01 sec)
    8. 事务1:
    9. 开启事务:
    10. START  TRANSACTION; 
    11. select * from posts where id = 1;
    12. COMMIT;
    13. 事务2:
    14. START TRANSACTION; 
    15. update posts set post_id = 2000 where id = 1;
    16. COMMIT;
  • 相关阅读:
    代码随想录第五十七天
    Flask 学习-26.JWT(JSON Web Token)生成Token
    栈溢出原理
    Spring核心问题回顾1:ioc容器创建的大致过程、bean的生命周期、解决循环依赖为什么需要三级缓存
    高并发场景中,数据库都有哪些优化手段?不会还有人不知道吧
    30行Python极简代码,10分钟get常用技巧
    他们在学校里不会教你的编程原则
    javaweb中前端向后端传值的几种方式
    你管这叫操作系统源码(十七)
    【LeetCode+JavaGuide打卡】Day22|235. 二叉搜索树的最近公共祖先、701.二叉搜索树中的插入操作、450.删除二叉搜索树中的节点
  • 原文地址:https://blog.csdn.net/qfzhangwei/article/details/128053199
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号