mysql查线上数据注意数据库的隔离级别

云掣YunChe11个月前技术文章590

数据库的隔离级别定义了一个事务可能对其他并发事务的可见性,以及它们可能对数据库的影响。隔离级别的选择影响着并发性能和数据的一致性,不同的隔离级别能够防止不同程度的并发问题,如脏读(Dirty Reads)、不可重复读(Nonrepeatable Reads)和幻读(Phantom Reads)。


SQL标准定义了四种隔离级别:


1. 读未提交 (Read Uncommitted)

这是最低的隔离级别,事务可以读取到其他未提交事务的更改。这意味着可能会出现脏读,即一个事务可能读到另一个事务未提交的数据。


例子:


事务A修改了一行数据但还未提交,此时事务B在此隔离级别下可以看到这个修改。


-- 事务A

BEGIN;

UPDATE accounts SET balance = balance - 100 WHERE id = 1;

 

-- 事务B

BEGIN;

SELECT balance FROM accounts WHERE id = 1; -- 可以看到事务A未提交的更改

 

2. 读提交 (Read Committed)

在这个隔离级别下,一个事务只能读取到其他事务已提交的更改。这避免了脏读,但仍然可能出现不可重复读,即在同一事务中两次相同的查询可能返回不同的结果。


例子:


-- 事务A

BEGIN;

UPDATE accounts SET balance = balance - 100 WHERE id = 1;

COMMIT;

 

-- 事务B

BEGIN;

SELECT balance FROM accounts WHERE id = 1; -- 第一次查询

-- 事务A提交更改

SELECT balance FROM accounts WHERE id = 1; -- 第二次查询,可能会看到不同的结果

COMMIT;

 

3. 可重复读 (Repeatable Read)

在这个隔离级别下,保证在同一事务中多次读取相同的数据会看到相同的结果,即不可重复读现象被防止了。但是,可能会出现幻读,即在同一事务中读取到其他事务新插入的行。


例子:


-- 事务A

BEGIN;

SELECT * FROM accounts WHERE balance > 1000; -- 第一次查询

 

-- 事务B

BEGIN;

INSERT INTO accounts (id, balance) VALUES (3, 2000);

COMMIT;

 

-- 事务A

SELECT * FROM accounts WHERE balance > 1000; -- 第二次查询可能包含了事务B新插入的行

COMMIT;

 

4. 串行化 (Serializable)

这是最高的隔离级别,它完全隔离了事务,使它们不能并行执行。任何并发的情况都会被阻止,从而避免脏读、不可重复读和幻读。但这也大大降低了并发性能。


例子:


-- 事务A

BEGIN;

SELECT * FROM accounts WHERE balance > 1000; -- 对结果集加锁

 

-- 事务B

BEGIN;

-- 尝试插入新行或更新满足上述SELECT条件的行将会被阻塞,直到事务A提交或回滚

INSERT INTO accounts (id, balance) VALUES (3, 2000); -- 被阻塞

 

在选择隔离级别时,通常需要在并发性能和数据一致性之间做出权衡。如果可接受一定程度的不一致性以获得更高的并发性能,可以选择较低的隔离级别(如读未提交或读提交)。如果数据一致性非常关键,可能需要选择较高的隔离级别(如可重复读或串行化)。


相关文章

Oozie web console is disabled 问题解决

Oozie web console is disabled 问题解决

一、问题一a、错误现象b、解决方案①、根据提示查看Oozie Quick Start 发现是缺少ExtJS 2.2库(必须是2.2版)下载ExtJS2.2下载地址:http://archive.clo...

HDFS核心参数

HDFS核心参数

1.NameNode内存生产配置(1)NameNode内存计算,每个文件块大概占用150byte,一台服务器128G内存为例,能存储9.1亿个文件128 * 1024 * 1024 * 1024  /...

 大数据集群监控配置操作指导(四)Spark监控使用jmx

大数据集群监控配置操作指导(四)Spark监控使用jmx

graphite_exporter方式Graphite 来收集度量标准,Grafana 则用于构建仪表板,首先,需要配置 Spark 以将 metrics 报告到 Graphite。prometheu...

大数据监控系列(一)——Prometheus+Grafana监控概述

大数据监控系列(一)——Prometheus+Grafana监控概述

1 概述这是介绍Prometheushe和Grafana主要是为了监控大数据产品,数栈平台也是使用Prometheushe+Grafana作为底层大数据组件的监控,并且均有配置模板,导入即在Grafa...

mysql表结构对比工具介绍

mysql表结构对比工具介绍

一、AmpNmp.DatabaseCompare工具1、工具特点:优点:比较两个数据库全部表结构的差异,包括表名、存储引擎、字符集、注释的不同,以及每张表中的字段名、数据类型、字符集、默认值、注释的不...

ES架构模型

ES架构模型

1.整体架构Elasticsearch是一个高度可扩展的开源全文搜索和分析引擎。它允许您快速、近实时地存储、搜索和分析大量数据。它通常用作支持具有复杂搜索功能和需求的应用程序的底层引擎/技术。Elas...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。