【随手记】MySQL快照读和当前读

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 【随手记】MySQL快照读和当前读

在MySQL中,当前读和快照读是针对事务隔离级别的概念。事务隔离级别决定了事务在读取数据时的一致性要求和并发控制方式。


  1. 当前读(Current Read):当前读获取的是数据的最新版本,可以读取到其他事务已经提交的更改。当前读可以保证读取到最新的数据,但可能会读取到未提交的数据。当前读需要使用排他锁(写锁)来保证数据的一致性,会影响其他事务对相同数据的并发操作。


例子:


-- 当前读示例
BEGIN;
SELECT * FROM table_name FOR UPDATE;
-- 对查询结果进行操作
COMMIT;


  1. 快照读(Snapshot Read):快照读获取的是事务开始时的数据版本,不会读取到其他事务未提交的更改。快照读可以提供一致性的非锁定读取,不会对其他事务造成阻塞或锁竞争。


例子:


-- 快照读示例
BEGIN;
SELECT * FROM table_name;
-- 对查询结果进行操作
COMMIT;


需要注意的是,当前读和快照读的实际行为还受到事务隔离级别和数据库配置的影响。默认情况下,MySQL的事务隔离级别为可重复读(Repeatable Read),这意味着默认情况下所有的SELECT语句都是快照读。如果需要使用当前读,可以使用FOR UPDATE或LOCK IN SHARE MODE子句来获取当前读。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
关系型数据库 MySQL 索引
【MySQL】当前读、快照读、MVCC
【MySQL】当前读、快照读、MVCC当前读:  select...lock in share mode (共享读锁)  select...for update  update , delete , insert   当前读, 读取的是最新版本, 并且对读取的记录加锁, 阻塞其他事务同时改动相同记录,避免出现安全问题。
12544 0
|
5月前
|
关系型数据库 MySQL 数据库
Mysql快照读和当前读
Mysql快照读和当前读
|
6月前
|
关系型数据库 MySQL
【随手记】MySQL中ROW_NUMBER()、RANK()和DENSE_RANK()函数的用法
【随手记】MySQL中ROW_NUMBER()、RANK()和DENSE_RANK()函数的用法
204 1
|
6月前
|
存储 SQL 关系型数据库
MySQL中的当前读和快照读及其区别
MySQL中的当前读和快照读及其区别
458 0
|
6月前
|
关系型数据库 MySQL Serverless
【随手记】MySQL窗口函数计算累加和
【随手记】MySQL窗口函数计算累加和
519 0
|
6月前
|
关系型数据库 MySQL 索引
【随手记】MySQL中的DISTINCT关键字
【随手记】MySQL中的DISTINCT关键字
81 0
|
7月前
|
关系型数据库 MySQL 数据库
【mysql】当前读和快照读,幻读和可重复读
【mysql】当前读和快照读,幻读和可重复读
440 0
|
运维 关系型数据库 MySQL
使用LVM快照备份MySQL
使用LVM快照备份MySQL
95 0
|
SQL 存储 监控
【MySQL技术内幕】8.6-快照备份和复制
【MySQL技术内幕】8.6-快照备份和复制
690 0
|
SQL 关系型数据库 数据库
RDS SQL Server 如何设置为快照隔离级别 READ_COMMITTED_SNAPSHOT
RDS SQL Server 如何设置为快照隔离级别 READ_COMMITTED_SNAPSHOT