码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 数据库事务——快照读与当前读


    文章目录

    • 快照读与当前读
      • 当前读
      • 快照读
    • RR下快照建立时机探究
      • 1. 快照建立时机——第一次 select 时
      • 2. 快照建立时机——事务启动时
      • 3. 快照建立时机——修改数据时

    快照读与当前读

    当前读

    当前读:读取最新提交的数据

    例如下面语句都会按最新提交的数据进行操作:

    • select … for update
    • select ... lock in share mode
    • insert、update、delete

    当前读本质上是基于锁的并发读操作

    快照读

    快照读:读取某一个快照建立时(可以理解为某一时间点)的数据,也称为一致性读。

    快照读主要体现在 select 时,而不同隔离级别下,select 的行为不同

    • 在 Serializable (串行化)隔离级别下 - 普通 select 也变成当前读,即加共享读锁

    • 在 RC(读提交) 隔离级别下 - 每次 select 都会建立新的快照

    • 在 RR (可重复读)隔离级别下

      • 事务启动后,首次 select 会建立快照
      • 如果事务启动选择了 with consistent snapshot,事务启动时就建立快照
      • 基于旧数据的修改操作,会重新建立快照

    所以快照读本质上读取的是历史数据(原理是回滚段),属于无锁查询。

    RR下快照建立时机探究

    1. 快照建立时机——第一次 select 时

    tx1tx2
    set session transaction isolation level repeatable read;
    start transaction;
    select * from account; /* 此时建立快照,两个账户为 1000 */
    update account set balance = 2000 where accountNo=1;
    select * from account; /* 两个账户仍为 1000 */

    这里的快照一旦建立,以后的查询都基于此快照,因此 tx1 中第二次 select 仍然得到 1 号账户余额为 1000

    如果 tx2 的 update 先执行

    tx1tx2
    set session transaction isolation level repeatable read;
    start transaction;
    update account set balance = 2000 where accountNo=1;
    select * from account; /* 此时建立快照,1号余额已经为2000 */

    2. 快照建立时机——事务启动时

    如果希望事务启动时就建立快照,可以添加 with consistent snapshot 选项

    tx1tx2
    set session transaction isolation level repeatable read;
    start transaction with consistent snapshot; /* 此时建立快照,两个账户为 1000 */
    update account set balance = 2000 where accountNo=1;
    select * from account; /* 两个账户仍为 1000 */

    这里添加了添加 with consistent snapshot 选项,快照就会在事务启动时建立,以后的查询都基于此快照,因此 tx1 中第二次 select 仍然得到 1 号账户余额为 1000

    3. 快照建立时机——修改数据时

    tx1tx2
    set session transaction isolation level repeatable read;
    start transaction;
    select * from account; /* 此时建立快照,两个账户为 1000 */
    update account set balance=balance+1000 where accountNo=1;
    update account set balance=balance+1000 where accountNo=1;
    select * from account; /* 1号余额为3000 */

    tx1 内的修改必须重新建立快照,否则,就会发生丢失更新的问题

  • 相关阅读:
    【手把手】教你玩转SpringCloud Alibaba之Seata
    流行的Python库numpy及Pandas简要介绍
    如何设计鞋材出库入账管理系统
    lambda 表达式
    【NodeJs-5天学习】第一天篇③ —— VsCode上运行第一个NodeJs 程序,配置自动重启插件 nodemon
    HelloWorld显示Go语言交叉编译的强大20230926
    【云原生 • Docker】docker 环境搭建、docker 与容器常用指令大全
    【linux环境下安装opencv3.4.5】
    【计算机网络】HTTPS
    设计模式——行为型设计模式
  • 原文地址:https://blog.csdn.net/weixin_45525272/article/details/126491792
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号