问题背景:前几天在项目中遇到 两个进程 query MySQL数据不一致的情况,现象是进程A在insert 后,进程B select 不出来。后来发现 A B 都是用了事务,B中设置了autocommit = 0 表示手动提交事务。
问题分析:由于数据库有事务隔离机制,不同的事务隔离级别会导致两个事务查询出不同的结果。详细资料见《参考资料》,其实质就是两个不同的事务在修改增加数据后是否对另一个事务可见的问题。
SQL标准规定了以下四种隔离级别。
假如有A B 两个事务;
一、Read uncommitted (读未提交)
最低的事务隔离级别,,在事务B未commit前,A事务就能查询到B事务中的对数据的变化。这种级别下,可能会导致脏读(dirty reads)。
二、Read committed(读已提交)
在事务B commit后,事务A才能看到B 提交的数据。但是事务A中查询两次,可能两次的记录是不一样的。也就是不可以重复读。
三、Repeatable reads(可重复读)
通过一定的锁机制,事务A 在过程中查询到的数据都是一致的。这个是MySQL的默认隔离级别。也就是说在B已经插入新数据并且commit后,在A事务中是体现不出来的。
但是可能会产生幻读。也就是说这种级别下没有加范围锁,其他事务部能更改A所选的事务,但是可以增加新的数据。
四、Serializable,可串行化
这是最高的事务隔离级别,通过对读取和更新的记录加锁,使多个事务串行工作。避免了上述碰到的各种脏读等问题。但是是以性能为代价的。
注:
在数据库中运行下边代码可以查看对于的事务级别。
select @@TX_ISOLATION;
需要注意的是,操作具体表时还需要看表的引擎,比如MyISAM 是不支持事务的,而InnoDB是支持事务的。也就是说不管你的事务隔离机制如何, MyISAM 类型的表都可以立即查询到已经真 实存储在数据库中的记录。也就是说只有支持事务的引擎才会受上边事务隔离级别的影响。
名词解释:
脏读:一个事务A可以看到另一个事务B未提交的内容。由于事务B未commit。所以数据后续可能会被rollback。在rollback后,A读取到的数据就称之为脏数据。
参考资料:
事务隔离级别:https://en.wikipedia.org/wiki/Isolation_(database_systems)
相关推荐
MySQL事务隔离级别是数据库管理系统中一个非常重要的概念,它关系到数据的一致性和并发性能。在MySQL中,事务被用于确保数据库操作的原子性、一致性、隔离性和持久性(ACID特性)。事务隔离级别主要涉及四个方面:读...
深入理解Mysql事务隔离级别与锁机制 Mysql事务隔离级别与锁机制是数据库系统中非常重要的概念,它们都是为了解决多事务并发问题而设计的。下面我们将深入讲解这些机制,让大家彻底理解数据库内部的执行原理。 事务...
三、MySQL事务隔离级别 MySQL通过设置不同的事务隔离级别来解决并发问题。隔离级别越高,并发性能越低,但数据一致性越好。 1. 读未提交(read-uncommitted):允许事务读取未提交的数据,不能防止脏读,是最宽松的...
详解Mysql事务隔离级别与锁机制 本篇文章详细介绍了Mysql事务隔离级别与锁机制的概念、原理和应用。事务隔离级别是数据库系统中的一种机制,用于解决多事务并发问题,包括脏写、不可重复读、幻读等问题。锁机制是...
"深入理解Mysql事务隔离级别与锁机制" 事务隔离级别是数据库系统中的一种机制,用于解决多事务并发问题,使得事务之间的执行不受影响。这种机制可以分为四个级别:Read Uncommitted、Read Committed、Repeatable ...
MySQL事务隔离级别详解 事务概念是数据库并发操作的最小控制单位,它是包含了一组有序的数据库操作命令的序列。事务的特性包括原子性、一致性、隔离性和永久性。原子性是指事务包含的数据库操作命令要么都执行,...
Mysql事务隔离级别.docx
MySQL事务隔离级别是数据库管理系统中确保事务之间正确交互的重要机制,它主要涉及到四个级别:读未提交(READ UNCOMMITTED)、读已提交(READ COMMITTED)、可重复读(REPEATABLE READ)和串行化(SERIALIZABLE)。...
MySQL中的事务隔离级别是数据库管理系统确保事务之间相互独立的重要机制,它主要针对并发操作时可能出现的问题,如脏读、不可重复读和幻读等。在MySQL的InnoDB存储引擎中,有四种不同的事务隔离级别: 1. **读未...
4-7深入理解Mysql事务隔离级别与锁机制.mp4
4-6深入理解Mysql事务隔离级别与锁机制.mp4
查询:默认事务隔离级别 mysql> select @@tx_isolation;当前会话的默认事务隔离级别 mysql> select @@session.tx_isolation;当前会话的默认事务隔离级别 mysql> select @@global.tx_isolation;全局的事务隔离级别
本知识点将深入探讨MySQL中的事务隔离级别和锁机制,这是确保数据一致性和并发控制的关键概念。 首先,让我们了解什么是事务。在数据库中,事务是一系列操作的集合,这些操作被视为一个逻辑工作单元,要么全部执行...
MySQL数据库的事务隔离级别是数据库管理系统中用于控制事务处理中并发操作的重要机制。在多用户同时访问数据库的情况下,事务隔离级别能够确保数据的一致性和完整性,避免并发操作带来的各种问题,如脏读、不可重复...
事务隔离级别 课程目标 了解 —— 事务隔离级别的概念; 理解 —— 事务隔离的四种级别; 掌握 —— 事务隔离级别的设置; 事务隔离级别 事务隔离:每一个事务都有一个所谓的隔离级,它定义了用户彼此之间隔离和交互...
MySQL 事务隔离级别是数据库管理系统为了确保数据一致性而设置的一系列规则,它们定义了在一个事务中,用户可以读取到其他事务中哪些修改过的数据。本文主要探讨的是“读提交”(READ-COMMITTED)这一隔离级别。 在...