热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

mysql事宜的四种隔离级别

mysql事务的四种隔离级别!--[if!mso]stylev:*{behavior:url(#default#VML);}o:*{behavior:url(#default#VML);}w:*{behavior:url(#default#VML);}.shape{behavior:url(#default#VML);}style![endif]--?我们知道事务有四种特性?(1)原

mysql 事务的四种隔离级别 !--[if !mso] style v\:* {behavior:url(#default#VML);} o\:* {behavior:url(#default#VML);} w\:* {behavior:url(#default#VML);} .shape {behavior:url(#default#VML);} /style ![endif]-- ? 我们知道事务有四种特性 ? ( 1 )原

mysql 事务的四种隔离级别

?

我们知道事务有四种特性

?

1)原子性:一个事务被视为不可分割的一个单位

?

2)隔离性:事务之间隔离开来,一个事务所做的修改,未提交之前另一个事务是不可见的

?

3)永久性:事务的更改是永久的

?

4)一致性:数据库总是从一个一致性的状态转换到另外一个一致性的状态中

?

?

?

在此之前,我们来学习一下mysql 如何设置隔离级别

?

SELECT@@global.tx_isolation;

?

SELECT@@session.tx_isolation;

?

SELECT@@tx_isolation;

?

set tx_isolation = 'read-uncommited';设置默认隔离级别

?

1、默认:下一个事务开始

?

2session:当前链接

?

3global:从此开始,全局都是

?

隔离级别:

?

1Read Uncommited(读未提交):发生脏读

?

?客户端A

?

开始状态:

?




?
?

?

客户端B

?

?

2、客户端A开始事务,但是没有提交,客户端B可以看到

?

1)、客户端A的状态:

?




?
?

?

?

?

客户端B的状态:

?

?

?




?
?

?

?

?

2)开始事务,并在客户端改变值

?




?
?

?

?

?

3)这时候查看客户端B,可以看到变化,这就是脏读现象

?




?
?

?

?

?

2Read Committed (读提交):容易发生“不可重复读”

?

1、首先先改变两边的状态

?

客户端A

?

?

?

?

?




?
?

?

?

?

客户端B

?




?
?

?

2、客户端A开始事务,客户端B也开始事务

?

?

?




?
?

?

3、这时候A更新一条记录,并且提交完毕,B未提交事务,又读了一次,这时候,两次读的数据不一致,导致了不可重复读

?

?

?

客户端A

?

?

?




?
?

?

?

?

客户端B

?





?
?
?

?

?

?

简单的来说

?

客户端A

客户端B

事务开始

事务开始

?

读字段namelin

更新字段name=qin

?

提交事务

?

?

读字段nameqin,两次读都不一致

?

提交事务

?

?

?

?

?

3Repeatable Read(可重复读):幻读现象

?

简单的用表格表示下:

?

客户端A

客户端B

事务开始

事务开始

name=lin

?

?

更新name=qin

?

Commit提交事务

name还是为lin

事务2开始

?

插入一条数据

?

?

?

?

?

?

?

1、???????? 改变事务隔离级别

?





?
?
?

?

2、???? 客户端B改变并且提交

?





?
?
?

?

?

?

3、???? 客户端A两次读都未发生不可重复读现象

?

?

?

?

?




?
?

?

?

?

4、???????? 客户端B插入一条记录(还未提交)

?




?
?

?

?

?

5、???????? 查看客户端A未发生变化,这时候客户端B提交

?




?
?

?

?

?

6、???????? 再次查看客户端A的数据,还是没有发生任何问题

?

?

?



?

?

?

?

所以mysql到了repeatable read级别之后,没有出现任何问题

?

这是因为innoDB存储引擎通过MVCC(多版本控制)解决了幻读的问题。

?

推荐阅读
  • Java实战之电影在线观看系统的实现
    本文介绍了Java实战之电影在线观看系统的实现过程。首先对项目进行了简述,然后展示了系统的效果图。接着介绍了系统的核心代码,包括后台用户管理控制器、电影管理控制器和前台电影控制器。最后对项目的环境配置和使用的技术进行了说明,包括JSP、Spring、SpringMVC、MyBatis、html、css、JavaScript、JQuery、Ajax、layui和maven等。 ... [详细]
  • MySQL中的MVVC多版本并发控制机制的应用及实现
    本文介绍了MySQL中MVCC的应用及实现机制。MVCC是一种提高并发性能的技术,通过对事务内读取的内存进行处理,避免写操作堵塞读操作的并发问题。与其他数据库系统的MVCC实现机制不尽相同,MySQL的MVCC是在undolog中实现的。通过undolog可以找回数据的历史版本,提供给用户读取或在回滚时覆盖数据页上的数据。MySQL的大多数事务型存储引擎都实现了MVCC,但各自的实现机制有所不同。 ... [详细]
  • MySQL数据库锁机制及其应用(数据库锁的概念)
    本文介绍了MySQL数据库锁机制及其应用。数据库锁是计算机协调多个进程或线程并发访问某一资源的机制,在数据库中,数据是一种供许多用户共享的资源,如何保证数据并发访问的一致性和有效性是数据库必须解决的问题。MySQL的锁机制相对简单,不同的存储引擎支持不同的锁机制,主要包括表级锁、行级锁和页面锁。本文详细介绍了MySQL表级锁的锁模式和特点,以及行级锁和页面锁的特点和应用场景。同时还讨论了锁冲突对数据库并发访问性能的影响。 ... [详细]
  • 本文讨论了在shiro java配置中加入Shiro listener后启动失败的问题。作者引入了一系列jar包,并在web.xml中配置了相关内容,但启动后却无法正常运行。文章提供了具体引入的jar包和web.xml的配置内容,并指出可能的错误原因。该问题可能与jar包版本不兼容、web.xml配置错误等有关。 ... [详细]
  • 数据库锁的分类和应用
    本文介绍了数据库锁的分类和应用,包括并发控制中的读-读、写-写、读-写/写-读操作的问题,以及不同的锁类型和粒度分类。同时还介绍了死锁的产生和避免方法,并详细解释了MVCC的原理以及如何解决幻读的问题。最后,给出了一些使用数据库锁的实际场景和建议。 ... [详细]
  • 本文介绍了Sencha Touch的学习使用心得,主要包括搭建项目框架的过程。作者强调了使用MVC模式的重要性,并提供了一个干净的引用示例。文章还介绍了Index.html页面的作用,以及如何通过链接样式表来改变全局风格。 ... [详细]
  • Todayatworksomeonetriedtoconvincemethat:今天在工作中有人试图说服我:{$obj->getTableInfo()}isfine ... [详细]
  • 从零基础到精通的前台学习路线
    随着互联网的发展,前台开发工程师成为市场上非常抢手的人才。本文介绍了从零基础到精通前台开发的学习路线,包括学习HTML、CSS、JavaScript等基础知识和常用工具的使用。通过循序渐进的学习,可以掌握前台开发的基本技能,并有能力找到一份月薪8000以上的工作。 ... [详细]
  • Asp.net Mvc Framework 七 (Filter及其执行顺序) 的应用示例
    本文介绍了在Asp.net Mvc中应用Filter功能进行登录判断、用户权限控制、输出缓存、防盗链、防蜘蛛、本地化设置等操作的示例,并解释了Filter的执行顺序。通过示例代码,详细说明了如何使用Filter来实现这些功能。 ... [详细]
  • 本文介绍了ASP.NET Core MVC的入门及基础使用教程,根据微软的文档学习,建议阅读英文文档以便更好理解,微软的工具化使用方便且开发速度快。通过vs2017新建项目,可以创建一个基础的ASP.NET网站,也可以实现动态网站开发。ASP.NET MVC框架及其工具简化了开发过程,包括建立业务的数据模型和控制器等步骤。 ... [详细]
  • 本文讲述了作者从最初对软件工程的选择迷茫到逐渐喜欢并坚持学习的经历。作者在大学期间通过学习专业课和参与项目开发,不断挑战自己并取得成就感。虽然曾考虑过转专业和复读,但最终决定坚持学习软件工程,并为自己的未来努力奋斗。作者还提到了大学生活与自己最初的预期不同,但对此并没有太多抱怨。 ... [详细]
  • 使用J2SE模拟MVC模式开发桌面应用程序的工程包的介绍
    以我开发过的一个娱乐管理系统为例:下图为我系统的业务逻辑的MVC流程:下图为以Eclipse开发中各包的说明:转载于:https:blog ... [详细]
  • wpf+mvvm代码组织结构及实现方式
    本文介绍了wpf+mvvm代码组织结构的由来和实现方式。作者回顾了自己大学时期接触wpf开发和mvvm模式的经历,认为mvvm模式使得开发更加专注于业务且高效。与此同时,作者指出mvvm模式相较于mvc模式的优势。文章还提到了当没有mvvm时处理数据和UI交互的例子,以及前后端分离和组件化的概念。作者希望能够只关注原始数据结构,将数据交给UI自行改变,从而解放劳动力,避免加班。 ... [详细]
  • 本文讨论了在ASP中创建RazorFunctions.cshtml文件时出现的问题,即ASP.global_asax不存在于命名空间ASP中。文章提供了解决该问题的代码示例,并详细解释了代码中涉及的关键概念,如HttpContext、Request和RouteData等。通过阅读本文,读者可以了解如何解决该问题并理解相关的ASP概念。 ... [详细]
  • SpringMVC工作流程概述
    SpringMVC工作流程概述 ... [详细]
author-avatar
天天火火红红
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有