iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >mysql数据库隔离级别详解
  • 164
分享到

mysql数据库隔离级别详解

摘要

目录隔离级别一、Mysql有四个事务隔离级别二、为什么默认RR隔离级别?三、RR隔离级别下手动加锁解决幻读理论基础脏读、不可重复读、幻读 及其解决方法事务隔离级别命令行操作操作验证一、实现脏读二、操作验证--实现不可重复

隔离级别

一、mysql有四个事务隔离级别

每个级别都有字符或数字编号

  1. 读未提交 READ UNCOMMITTED | 0 : 存在脏读,不可重复度,幻读的问题。 
  2. 读已提交 READ COMMITTED | 1 : 解决脏读问题,存在不可重复读,幻读的问题。
  3. 可重复读 REPEATABLE READ | 2 : 解决脏读,不可重复读的问题,存在幻读,默认隔离级别,使用mvcC机制实现可重复读。
  4. 序列化 SERIALIZABLE | 3 : 解决脏读,不可重复读,幻读,可保证事务安全,但完全串行执行,性能最低。

我有记忆方法,先是RU、RC, 记住UC顺序,联想到UC WEB

二、为什么默认RR隔离级别?

RR级别作为mysql事务默认隔离级别,是事务完全和性能的折中。SERIALIZABLE级别是悲观地认为幻读时刻都会发生,故会自动地隐式地对事务所需资源加排他锁,其他事务访问此资源会被阻塞等待,故事务是安全的,但需要认值考虑性能。

三、RR隔离级别下手动加锁解决幻读理论基础

InnoDB的行锁锁定的是索引,而不是记录本身。索引映射的记录存在就加行锁,如果不存在则会加next-key lock/gap锁/间隙锁, 故InnoDB可以实现事务对某记录的预先占用。

脏读、不可重复读、幻读 及其解决方法

脏读

  • 一个事务读取到另一个事务还没有提交的数据。解决方法:把事务隔离级别调整到READ COMMITTED。

不可重复读

  • 一个事务先后读取同一条记录,但两次读取的数据不同,我们称之为不可重复读。解决方法:把事务隔离级别调整到REPEATABLE READ。

幻读

  • 网上很多文章都说一个事务执行范围查询,两次select得到的条数不同,就叫幻读,这是错误的!!!
  • 幻读并不是说两次读取获取的结果集不同,幻读是指某一次select操作得到的结果所表征的数据状态无法支持后续的业务操作,具体例子:select某记录是否存在,不存在,准备插入此记录,但执行insert时发现此记录已存在,无法插入,此时就发生了幻读。
  • 还一种理解思路,就是因为先采用了"快照读",然后又用了"当前读",发现结果不同。比如先select是快照读,然后update、insert等,这时会用到当前读,发现操作出现未预料结果。

幻读解决方法

1、把事务隔离级别调整到SERIALIZABLE。2、RR隔离级别下,对select操作手动加行锁,select ... for update,这也序列化隔离级别下隐式会做的事。

参考文章

幻读  https://www.jb51.net/article/251790.htm

事务隔离级别命令行操作

1、查看隔离级别

1)查看当前会话隔离级别

mysql> SELECT @@tx_isolation;
+-----------------+
| @@tx_isolation  |
+-----------------+
| REPEATABLE-READ |
+-----------------+
1 row in set, 1 warning (0.00 sec)

2)查看系统隔离级别

mysql> select @@global.tx_isolation;
+-----------------------+
| @@global.tx_isolation |
+-----------------------+
| READ-UNCOMMITTED      |
+-----------------------+
1 row in set, 1 warning (0.00 sec)

2、设置隔离级别

SET [SESSION|GLOBAL] TRANSACTION ISOLATION LEVEL [READ UNCOMMITTED|READ COMMITTED|REPEATABLE READ|SERIALIZABLE]

1)设置当前会话

mysql> set session transaction isolation level repeatable read;
Query OK, 0 rows affected (0.00 sec)

2)设置系统

mysql> set global transaction isolation  level read uncommitted;                
Query OK, 0 rows affected (0.00 sec)3、命令行,开始事务时用

操作验证

自己在命令行去验证几种隔离级别下的读问题。

一、实现脏读

在不可提交读, 也就是READ UNCOMMITED情况下,会产生脏读。

mysql数据库隔离级别详解

二、操作验证--实现不可重复读

在可提交读, 也就是READ COMMITED情况下,会产生不可重复读。

mysql数据库隔离级别详解

三、操作验证--解决不可重复读

repeatable read(MySQL默认隔离级别),这时候能解决可重复读。

右边事务提交了,修改了age=29,左边再次查询,还是28。

mysql数据库隔离级别详解

四、操作验证--实现幻读

repeatable read(MySQL默认隔离级别),这时候还会出现幻读。

mysql数据库隔离级别详解

总结

到此这篇关于mysql数据库隔离级别文章就介绍到这了,更多相关mysql隔离级别内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: mysql数据库隔离级别详解

本文链接: https://www.lsjlt.com/news/32960.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL事务隔离级别详解
    一、什么是事务? 事务是逻辑上的一组操作,要么全执行,要么全不执行。 事务最经典栗子也经常被拿出来的栗子就是银行转账了。比如小明要给小红转账1000元,这个转账会涉及到两个关键操作:将小明的余额减1000元,将小红的余额减1000元。万一这...
    99+
    2023-08-30
    mysql
  • mysql如何查看数据库隔离级别
    要查看MySQL数据库的隔离级别可以使用以下步骤: 1、打开 MySQL 命令行客户端或者数据库管理工具,连接到目标数据库。 2、执...
    99+
    2024-04-17
    mysql
  • 数据库事务隔离级别:为你的数据库选择合适的隔离级别
    什么是数据库事务隔离级别 数据库事务隔离级别是指,在数据库系统中,当多个事务同时访问和修改数据时,为了保证数据的一致性和完整性,而采取的隔离机制。事务隔离级别决定了一个事务在什么情况下可以看到其他并发事务对数据库的修改。 事务隔离级别的类...
    99+
    2024-02-10
    数据库 事务 隔离级别 并发访问 数据完整性 一致性
  • 数据库隔离级别有哪些
    小编给大家分享一下数据库隔离级别有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!数据库隔离级别包括:1、读未提交;2、读已提...
    99+
    2024-04-02
  • 【数据库的四种隔离级别】
    在关系型数据库中,隔离级别是指多个事务并发执行时,彼此之间的隔离程度。数据库的四种隔离级别如下: 1.读未提交(Read Uncommitted): 最低级别的隔离级别,一个事务可以读取到另一个事务未提交的数据,可能会出现脏读、不可重复读和...
    99+
    2023-08-19
    数据库 java 开发语言
  • 数据库事务隔离的级别
    本篇内容介绍了“数据库事务隔离的级别”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1 概述与背景这是数据库...
    99+
    2024-04-02
  • mysql隔离级别详解及示例
    目录mysql的4种隔离级别创建数据表:设置隔离级别只是单纯知道事物的隔离级别,但是从未操作过 今日操作一次。 脏读(Drity Read):某个事务已更新一份数据,另一个事务在此时...
    99+
    2024-04-02
  • 数据库中有哪些隔离级别
    数据库中有哪些隔离级别?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1,读未提交,Read Uncommited。指的是一个事务读取到另外一个...
    99+
    2024-04-02
  • spring数据库隔离级别是什么
    Spring框架提供了对数据库事务的支持,其中包括设置事务的隔离级别。数据库的隔离级别是指多个事务并发执行时,彼此之间的可见性和影响...
    99+
    2023-10-25
    spring 数据库
  • mysql事务隔离级别详情
    serializable 串行化(无问题) 事务必须以顺序的方式执行,前一个事务提交之前后面的事务无法进行提交,最安全,但是不能并发操作,导致效率低下. repeatab re...
    99+
    2024-04-02
  • MySQL数据中有哪些数据隔离级别
    小编给大家分享一下MySQL数据中有哪些数据隔离级别,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!    &...
    99+
    2024-04-02
  • 数据库的事务隔离级别怎么理解
    本篇内容主要讲解“数据库的事务隔离级别怎么理解”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“数据库的事务隔离级别怎么理解”吧!在MVCC并发控制中,读操作可以分...
    99+
    2024-04-02
  • mysql数据库四种事务隔离级别是什么
    这篇文章主要介绍了mysql数据库四种事务隔离级别是什么,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。熟悉 mysql 数据库四种事务隔离级别:...
    99+
    2024-04-02
  • 数据库事务隔离级别是什么
    这篇文章主要介绍了数据库事务隔离级别是什么,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。数据库事务隔离级别:1、Read Uncommitt...
    99+
    2024-04-02
  • 数据库事务隔离级别详解:让数据操作如履平地
    数据库事务隔离级别 数据库事务隔离级别是数据库在执行事务过程中,对其他并发事务的影响程度。不同的隔离级别提供了不同的数据一致性,以满足不同的应用程序需求。在SQL Server中,有四种隔离级别: Read Uncommitted(未提...
    99+
    2024-02-25
    数据库 事务 隔离级别 并发控制
  • 数据库事务隔离级别详解:让数据操作更加高效
    数据库事务隔离级别介绍 数据库事务隔离级别是控制数据库并发访问的一种机制,它可以保证在多个并发事务同时操作数据库时,数据的完整性与一致性。事务隔离级别共有四个级别,分别是: 未提交读(Read Uncommitted):该级别允许一个...
    99+
    2024-02-25
    数据库 事务 隔离级别 并发访问 数据完整性 数据一致性
  • 【MySQL】事务及其隔离性/隔离级别
    需要云服务器等云产品来学习Linux的同学可以移步/-->腾讯云-->阿里云-->华为云 show variables like 'autocommit';+---------------+-------+| Variable_name...
    99+
    2023-09-01
    mysql 数据库
  • mysql事务隔离的级别
    这篇文章主要介绍“mysql事务隔离的级别”,在日常操作中,相信很多人在mysql事务隔离的级别问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql事务隔离的级别”的疑惑...
    99+
    2024-04-02
  • MySQL隔离级别有哪些
    这篇文章将为大家详细讲解有关MySQL隔离级别有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。业务的特性  业务是有四个特性(ACID)的,分别是原子性...
    99+
    2024-04-02
  • Mysql有哪些隔离级别
    今天就跟大家聊聊有关Mysql有哪些隔离级别,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。  什么是事务  事务是应用程序中一系列严密的操作,所有操...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作