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


    在这之前介绍了mysql隔离级别最低的一种事务级别 Read Uncommitted

    在Read Committed隔离级别下,一个事务可能会遇到不可重复读(Non Repeatable Read)的问题。不可重复读是指,在一个事务内,多次读同一数据,在这个事务还没有结束时,如果另一个事务恰好修改了这个数据,那么,在第一个事务中,两次读取的数据就可能不一致。

    但同时,这种隔离级别也避免了出现脏读。

    我们来测试一下,首先准备一个有数据的student表:

    然后,分别开启两个MySQL客户端连接,按顺序依次执行事务A和事务B:

    时刻事务A事务B
    1SET TRANSACTION ISOLATION LEVEL READ COMMITTED;SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
    2BEGIN;BEGIN;
    3SELECT * FROM student; 
    4UPDATE student SET name = '小王' WHERE id = 1;
    5SELECT * FROM student; 
    6COMMIT;
    7SELECT * FROM student;
    8COMMIT;

     

     当事务B第一次执行第3步的查询时,得到的结果是 张三 ,随后,事务A在第4步更新了这条记录没有提交,事务B在第5步再次执行同样的查询时,得到的结果还是 张三 ,事务A在第6步提交事务后,事务B在第7步再次查询,得到的结果还是 小王 。因此,在Read Committed隔离级别下,事务不可重复读同一条记录,因为很可能读到的结果不一致,但同时也避免了脏读。

  • 相关阅读:
    树莓派快速上手-远程调试图形界面
    算法总结--线段树
    五、点击切换、滚动切换、键盘切换
    【Git1】指令,分支,ssh免密登录
    CSDN 界面布局优化
    js其他方法
    Socket套接字
    【Linux】文件重定向以及一切皆文件
    短视频内容运营师是做什么的,行业前景如何?
    CleanMyMac XMac苹果电脑专属系统优化工具
  • 原文地址:https://blog.csdn.net/lwpoor123/article/details/126761077
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号