`
Tzhennan
  • 浏览: 57921 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

MySQL的事务隔离级别

 
阅读更多

第1级别:Read Uncommitted(读取未提交内容)

(1)所有事务都可以看到其他未提交事务的执行结果

(2)本隔离级别很少用于实际应用,因为它的性能也不比其他级别好多少

(3)该级别引发的问题是——脏读(Dirty Read):读取到了未提交的数据

 

#事务A:启动事务A

#事务B:启动事务B,在事务B中执行更新语句,且不提交

#事务A:那么这时候事务A能看到事务B还没有提交的数据

#事务B:事务B回滚,仍然未提交

#事务A:在事务A里面看到的也是B没有提交的数据

脏读意味着我在这个事务中(A中),事务B虽然没有提交,但它任何一条数据变化,我都可以看到。

 

第2级别:Read Committed(读取提交内容)

(1)这是大多数数据库系统的默认隔离级别(但不是MySQL默认的)

(2)它满足了隔离的简单定义:一个事务只能看见已经提交事务所做的改变

(3)这种隔离级别出现的问题是——不可重复读(Nonrepeatable Read):不可重复读意味着我们在同一个事务中执行完全相同的select语句时可能看到不一样的结果。

导致这种情况的原因可能有:(1)有一个交叉的事务有新的commit,导致了数据的改变;(2)一个数据库被多个实例操作时,同一事务的其他实例在该实例处理其间可能会有新的commit

 

#事务A:启动事务A

#事务B:启动事务B,在事务B中执行更新语句,且不提交

#事务A:那么这时候事务A不能看到事务B还没有提交的数据

#事务B:提交事务B

#事务A:在事务A里面看到的是B提交的数据

 

 

第3级别:Repeatable Read(可重读)

(1)这是MySQL的默认事务隔离级别

(2)它确保同一事务的多个实例在并发读取数据时,会看到同样的数据行

(3)此级别可能出现的问题——幻读(Phantom Read):当用户读取某一范围的数据行时,另一个事务又在该范围内插入了新行,当用户再读取该范围的数据行时,会发现有新的“幻影” 行

(4)InnoDB和Falcon存储引擎通过多版本并发控制(MVCC,Multiversion Concurrency Control)机制解决了该问题

 

#事务A:启动事务A

#事务B:启动事务B,在事务B中执行更新语句,并提交

#事务A:这时候即使事务B已经提交了,但A仍然不能看到数据变化(这个级别2不一样,也说明级别3解决了不可重复读问题)

#事务A:只有当事务A也提交了,它才能够看到数据变化

 

第4级别:Serializable(可串行化)

(1)这是最高的隔离级别

(2)它通过强制事务排序,使之不可能相互冲突,从而解决幻读问题。简言之,它是在每个读的数据行上加上共享锁。

(3)在这个级别,可能导致大量的超时现象和锁竞争

 

#事务A:开启一个新事务

#事务B:在A没有commit之前,这个交叉事务是不能更改数据的

分享到:
评论

相关推荐

    MySQL事务隔离级别

    MySQL事务隔离级别是数据库管理系统中一个非常重要的概念,它关系到数据的一致性和并发性能。在MySQL中,事务被用于确保数据库操作的原子性、一致性、隔离性和持久性(ACID特性)。事务隔离级别主要涉及四个方面:读...

    06-VIP-深入理解Mysql事务隔离级别与锁机制.pdf

    深入理解Mysql事务隔离级别与锁机制 Mysql事务隔离级别与锁机制是数据库系统中非常重要的概念,它们都是为了解决多事务并发问题而设计的。下面我们将深入讲解这些机制,让大家彻底理解数据库内部的执行原理。 事务...

    MySQL的四种事务隔离级别

    三、MySQL事务隔离级别 MySQL通过设置不同的事务隔离级别来解决并发问题。隔离级别越高,并发性能越低,但数据一致性越好。 1. 读未提交(read-uncommitted):允许事务读取未提交的数据,不能防止脏读,是最宽松的...

    详解Mysql事务隔离级别与锁机制.doc

    详解Mysql事务隔离级别与锁机制 本篇文章详细介绍了Mysql事务隔离级别与锁机制的概念、原理和应用。事务隔离级别是数据库系统中的一种机制,用于解决多事务并发问题,包括脏写、不可重复读、幻读等问题。锁机制是...

    深入理解Mysql事务隔离级别与锁机制.pdf

    "深入理解Mysql事务隔离级别与锁机制" 事务隔离级别是数据库系统中的一种机制,用于解决多事务并发问题,使得事务之间的执行不受影响。这种机制可以分为四个级别:Read Uncommitted、Read Committed、Repeatable ...

    MySQL事务隔离级别详解.docx

    MySQL事务隔离级别详解 事务概念是数据库并发操作的最小控制单位,它是包含了一组有序的数据库操作命令的序列。事务的特性包括原子性、一致性、隔离性和永久性。原子性是指事务包含的数据库操作命令要么都执行,...

    Mysql事务隔离级别.docx

    Mysql事务隔离级别.docx

    Mysql事务隔离级别原理实例解析

    MySQL事务隔离级别是数据库管理系统中确保事务之间正确交互的重要机制,它主要涉及到四个级别:读未提交(READ UNCOMMITTED)、读已提交(READ COMMITTED)、可重复读(REPEATABLE READ)和串行化(SERIALIZABLE)。...

    mysql事务隔离级别1

    MySQL中的事务隔离级别是数据库管理系统确保事务之间相互独立的重要机制,它主要针对并发操作时可能出现的问题,如脏读、不可重复读和幻读等。在MySQL的InnoDB存储引擎中,有四种不同的事务隔离级别: 1. **读未...

    4-7深入理解Mysql事务隔离级别与锁机制.mp4

    4-7深入理解Mysql事务隔离级别与锁机制.mp4

    4-6深入理解Mysql事务隔离级别与锁机制.mp4

    4-6深入理解Mysql事务隔离级别与锁机制.mp4

    MY SQL 事务隔离 查询:默认事务隔离级别

    查询:默认事务隔离级别 mysql> select @@tx_isolation;当前会话的默认事务隔离级别 mysql> select @@session.tx_isolation;当前会话的默认事务隔离级别 mysql> select @@global.tx_isolation;全局的事务隔离级别

    深入理解Mysql事务隔离级别与锁机制.zip

    本知识点将深入探讨MySQL中的事务隔离级别和锁机制,这是确保数据一致性和并发控制的关键概念。 首先,让我们了解什么是事务。在数据库中,事务是一系列操作的集合,这些操作被视为一个逻辑工作单元,要么全部执行...

    MySQL数据库事务隔离级别详解

    MySQL数据库的事务隔离级别是数据库管理系统中用于控制事务处理中并发操作的重要机制。在多用户同时访问数据库的情况下,事务隔离级别能够确保数据的一致性和完整性,避免并发操作带来的各种问题,如脏读、不可重复...

    MySQL数据库:事务隔离级别.pptx

    事务隔离级别 课程目标 了解 —— 事务隔离级别的概念; 理解 —— 事务隔离的四种级别; 掌握 —— 事务隔离级别的设置; 事务隔离级别 事务隔离:每一个事务都有一个所谓的隔离级,它定义了用户彼此之间隔离和交互...

    Mysql事务隔离级别之读提交详解

    MySQL 事务隔离级别是数据库管理系统为了确保数据一致性而设置的一系列规则,它们定义了在一个事务中,用户可以读取到其他事务中哪些修改过的数据。本文主要探讨的是“读提交”(READ-COMMITTED)这一隔离级别。 在...

Global site tag (gtag.js) - Google Analytics