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

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

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

例子:

sql 复制代码
-- 当前读示例
BEGIN;
SELECT * FROM table_name FOR UPDATE;
-- 对查询结果进行操作
COMMIT;
  1. 快照读(Snapshot Read):快照读获取的是事务开始时的数据版本,不会读取到其他事务未提交的更改。快照读可以提供一致性的非锁定读取,不会对其他事务造成阻塞或锁竞争。

例子:

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

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

相关推荐
�FENG20 分钟前
MySQL常见故障排查与性能优化
mysql·性能优化·常见故障
不剪发的Tony老师1 小时前
sqlite-vec:谁说SQLite不是向量数据库?
数据库·人工智能·sqlite
敲键盘的小夜猫2 小时前
Milvus向量Search查询综合案例实战(下)
数据库·python·milvus
钢铁男儿3 小时前
深入剖析C#构造函数执行:基类调用、初始化顺序与访问控制
java·数据库·c#
有时间要学习3 小时前
MySQL——事务
数据库·mysql
翻滚吧键盘3 小时前
Spring Boot,注解,@ComponentScan
java·数据库·spring boot
not coder3 小时前
Pytest Fixture 详解
数据库·pytest
小光学长4 小时前
基于vue框架的独居老人上门护理小程序的设计r322q(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库
weixin_472339464 小时前
MySQL优化全链路实践:从慢查询治理到架构升级
数据库·mysql·架构
运维老曾4 小时前
MySQ-8.42 MGR 组复制部署及详解
数据库·mysql