【MySQL】脏读、不可重复读、幻读介绍及代码解释

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS Agent(兼容OpenClaw),2核4GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: 【MySQL】脏读、不可重复读、幻读介绍及代码解释

51776395ebc54a8682a1954889672696.png

前言

       数据库事务隔离级别是关系数据库管理系统中一个重要的概念,它涉及到多个事务并发执行时如何保障数据的一致性和完整性。通过设置不同的隔离级别,开发者可以在一致性和性能之间做出权衡,根据应用的特点选择合适的隔离级别。然而,理解和正确使用隔离级别对于确保数据库系统的正确运行和数据的可靠性至关重要。在本文中,我们将深入探讨数据库事务隔离级别中的三个常见问题:脏读、不可重复读和幻读。

正文

脏读(Dirty Read)、不可重复读(Non-Repeatable Read)和幻读(Phantom Read)是数据库事务隔离级别中常见的问题,它们描述了在多个事务并发执行时可能出现的数据一致性问题。这些问题主要涉及到事务之间的读取和写入操作。

脏读(Dirty Read):

  • 概念: 一个事务读取了另一个事务尚未提交的数据。
  • 作用: 如果事务A读取了事务B的未提交数据,而B后来回滚,那么A读到的数据就是"脏数据",不准确且不稳定。
  • 代码示例:
-- 事务1
BEGIN TRANSACTION;
UPDATE Account SET balance = balance - 100 WHERE account_id = 123;
-- 此时未提交
 
-- 事务2
SELECT balance FROM Account WHERE account_id = 123; -- 脏读
COMMIT; -- 事务1回滚,事务2读到的数据是脏数据

不可重复读(Non-Repeatable Read):

  • 概念: 一个事务在多次读取同一数据时,得到的结果不一致,即中间可能有其他事务修改了这个数据。
  • 作用: 可能导致事务在处理相同数据时,由于其他事务的修改而得到不一致的结果。
  • 代码示例:
-- 事务1
BEGIN TRANSACTION;
SELECT balance FROM Account WHERE account_id = 123; -- 第一次读取
 
-- 事务2
UPDATE Account SET balance = balance - 50 WHERE account_id = 123;
COMMIT; -- 提交了一个更新
 
-- 事务1
SELECT balance FROM Account WHERE account_id = 123; -- 第二次读取,结果不一致
COMMIT;

幻读(Phantom Read):

  • 概念: 一个事务在多次查询时,得到了不同数量的符合条件的记录,这是由于其他事务插入、删除了符合条件的记录导致的。
  • 作用: 可能导致事务在处理一系列数据时,由于其他事务的插入或删除操作而得到不一致的结果。
  • 代码示例:
-- 事务1
BEGIN TRANSACTION;
SELECT COUNT(*) FROM Employee WHERE salary > 50000; -- 第一次查询
 
-- 事务2
INSERT INTO Employee (id, name, salary) VALUES (1001, 'John', 60000);
COMMIT; -- 提交了一个插入操作
 
-- 事务1
SELECT COUNT(*) FROM Employee WHERE salary > 50000; -- 第二次查询,结果不一致
COMMIT;

在SQL Server中,可以通过设置事务的隔离级别来控制这些问题。常见的隔离级别包括READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ和SERIALIZABLE。不同的数据库系统可能有不同的隔离级别实现方式和支持程度。以下是一个设置隔离级别的示例:

-- 设置隔离级别为READ COMMITTED
SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
 
-- 开始事务
BEGIN TRANSACTION;
 
-- 执行事务操作
 
-- 提交事务
COMMIT;

请注意,选择隔离级别时需要权衡一致性和性能之间的关系。更严格的隔离级别通常会导致性能下降,因为需要更多的锁和资源管理。

结语

        数据库事务隔离级别是数据库系统中维护数据一致性的关键组成部分。通过了解脏读、不可重复读和幻读这三个问题,我们能够更好地理解并预防在并发操作中可能出现的数据不一致情况。选择合适的隔离级别是一个权衡性能和数据一致性的过程,开发者需要根据应用的需求和特点来进行取舍。在实际开发中,深入理解事务隔离级别,并采用合适的机制来处理并发访问,将有助于提高数据库系统的可靠性和性能,确保应用能够以正确、可靠的方式运行。


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
消息中间件 缓存 弹性计算
纯PHP+MySQL手搓高性能论坛系统!代码精简,拒绝臃肿
本内容分享了一套经实战验证的社交系统架构设计,支撑从1到100万用户的发展,并历经6次流量洪峰考验。架构涵盖客户端层(App、小程序、公众号)、接入层(API网关、负载均衡、CDN)、业务服务层(用户、内容、关系、消息等服务)、数据层(MySQL、Redis、MongoDB等)及运维监控层(日志、监控、告警)。核心设计包括数据库分库分表、多级缓存体系、消息队列削峰填谷、CQRS模式与热点数据动态缓存。同时提供应对流量洪峰的弹性伸缩方案及降级熔断机制,并通过Prometheus实现全链路监控。开源建议结构清晰,适合大型社交平台构建与优化。
470 11
|
存储 SQL 关系型数据库
Mysql学习笔记(二):数据库命令行代码总结
这篇文章是关于MySQL数据库命令行操作的总结,包括登录、退出、查看时间与版本、数据库和数据表的基本操作(如创建、删除、查看)、数据的增删改查等。它还涉及了如何通过SQL语句进行条件查询、模糊查询、范围查询和限制查询,以及如何进行表结构的修改。这些内容对于初学者来说非常实用,是学习MySQL数据库管理的基础。
409 6
|
存储 关系型数据库 MySQL
Key_Value 形式 存储_5级省市城乡划分代码 (mysql 8.0 实例)
本文介绍了如何使用MySQL8.0数据库中的Key_Value形式存储全国统计用区划代码和城乡划分代码(5级),包括导入数据、通过数学函数提取省市区信息,以及查询5级行政区划的详细数据。
288 0
|
关系型数据库 MySQL 数据库
【MySQL-10】DCL-数据控制语言-【管理用户&权限控制】 (语法语句&案例演示&可cv案例代码)
【MySQL-10】DCL-数据控制语言-【管理用户&权限控制】 (语法语句&案例演示&可cv案例代码)
【MySQL-10】DCL-数据控制语言-【管理用户&权限控制】 (语法语句&案例演示&可cv案例代码)
|
关系型数据库 MySQL Linux
【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)
【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)
【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)
|
关系型数据库 MySQL 数据库
MySQL的脏读、幻读、不可重复度是什么
**脏读**:事务读取了未提交的修改,可能导致不一致。**不可重复读**:同一事务中相同查询返回不同结果,因其他事务修改。**幻读**:事务在范围查询时,另一事务插入数据,使行数不一致。SQL-92定义四种事务隔离级别来防止这些问题:序列化、可重复读、提交读、未提交读。
349 4
|
关系型数据库 MySQL 数据库
关系型数据库MySQL开发要点之多表设计案例详解代码实现
关系型数据库MySQL开发要点之多表设计案例详解代码实现
328 2
|
存储 关系型数据库 MySQL
MySQL数据库——存储过程-条件处理程序(通过SQLSTATE指定具体的状态码,通过SQLSTATE的代码简写方式 NOT FOUND)
MySQL数据库——存储过程-条件处理程序(通过SQLSTATE指定具体的状态码,通过SQLSTATE的代码简写方式 NOT FOUND)
232 0
MySQL数据库——存储过程-条件处理程序(通过SQLSTATE指定具体的状态码,通过SQLSTATE的代码简写方式 NOT FOUND)

推荐镜像

更多