事物的 隔离级别,说简单非常简单(新手也能说出 是个隔离级别 和 影响),说男也非常难。(很多 有几年编程 经验的程序员依旧搞不清楚)

废话不多少 直接开始:

事务的隔离级别 是用来描述 事务的读关系的,和写完全没有关系。所有数据库都不允许修改一个事务未提交的数据行。

Read Uncommitted(读取未提交内容)

  描述的是。一个未提交的事务里面修改的数据,可以立即被另一个事务查询到(  脏读(Dirty Read)  )

  实验设计1: 吧数据库隔离级别改成Read Uncommitted ,  两个方法 一个循环 查询 出指定 行,每查一次睡一秒。另一个方法 修改这 一行的数据,但是不提交事务(睡 100 秒) 。  先调用查询方法,然后调用修改方法,

  结果:修改立即被查询方法查询到。我们读到了脏数据。

Read Committed(读取提交内容)

    描述:只能读到已经提交的事务修改的数据,但是在 同一个事务的 2次查询中 ,可以读取到 另一个事务提交了的数据。

   实验式设计2: 吧数据库隔离级别改成Read Committed ,两个方法 一个循环 查询 出指定 行,每查一次睡一秒。另一个方法 修改这 一行的数据,并且提交事务 。  先调用查询方法,然后调用修改方法,

   结果: 用 实验1 验证 不能读到脏数据,用实验2 验证 2 修改可以被 感知。

  备注:实验2 可能会被缓存影响。如果没有发出多次查询sql ,那么就是缓存的影响了,需要关闭mybatis 的 缓存。

    springboot 关闭mybits 缓存的方法如下:

      

mybatis:
configuration:
cache-enabled: false
local-cache-scope: STATEMENT

  

     

Repeatable Read(可重读)

  

 描述:Repeatable Read 是mysql 的 默认级别 。  一般的解释 它 可以 避免 不可重复读,但是不能 避免幻读,但是 mysql InnoDB和Falcon存储引擎通过多版本并发控制(MVCC,Multiversion Concurrency Control)机制解决了该问题。

  也就是说 mysql 的这个级别已经不会出 幻读 了。关于幻读的解释:幻读 (Phantom Read)。简单的说,幻读指当用户读取某一范围的数据行时,另一个事务又在该范围内插入了新行,当用户再读取该范围的数据行时,会发现有新的“幻影” 行。

  实验3:修改实验2 ,查询 改成查询一共有多少行,修改 方法改成查询方法;

  结果:  利用实验2证明不在出现 不可重复读,利用 实验3 证明 InnoDB 解决了幻读。

  备注: InnoDB mysql 默认的 数据库引擎

Serializable(可串行化)  不管读事务还是写事务都加了独占锁。只能一个事务结束以后,赢一个事务才能执行。

  这个最好认证,查询事务没有提交的时候写事务是不能执行的。

怎么修改 mysql的  事务 隔离级别 和 查询 mysql的 隔离级别 在我的另一篇文章中:https://www.cnblogs.com/cxygg/p/9338555.html

mysql 事务隔离级别详解的更多相关文章

  1. MySQL事务隔离级别详解

    原文地址:http://xm-king.iteye.com/blog/770721 SQL标准定义了4类隔离级别,包括了一些具体规则,用来限定事务内外的哪些改变是可见的,哪些是不可见的.低级别的隔离级 ...

  2. mysql事务隔离级别详解和实战

    A事务做了操作 没有提交 对B事务来说 就等于没做 获取的都是之前的数据 但是 在A事务中查询的话 查到的都是操作之后的数据 没有提交的数据只有自己看得到,并没有update到数据库. 查看InnoD ...

  3. MYSQL事务隔离级别详解附加实验

    参考: https://dev.mysql.com/doc/refman/5.7/en/set-transaction.html http://xm-king.iteye.com/blog/77072 ...

  4. mysql 事务隔离级别 详解

    问题 在工作中真实遇到的问题:用python连接mysql,查询数据,同时有别的代码在更新mysql中的数据,前者是一直是保持连接的数据库,每一分钟select一次,但第二次却查不到更新后的数据?wh ...

  5. MySQL事务隔离级别详解(转)

    原文: http://xm-king.iteye.com/blog/770721 SQL标准对事务定义了4种隔离级别,包括了一些具体规则,用来限定事务内外的哪些改变是可见的,哪些是不可见的.低级别的隔 ...

  6. MySQL四种事务隔离级别详解

    本文实验的测试环境:Windows 10+cmd+MySQL5.6.36+InnoDB 一.事务的基本要素(ACID) 1.原子性(Atomicity):事务开始后所有操作,要么全部做完,要么全部不做 ...

  7. MySQL事务,事务隔离级别详解

    1.什么是事务 指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行. 2.事务的4个特性 原子性(Atomicity).一致性(Consistency).隔离性(Isolatio ...

  8. MySQL 四种事务隔离级别详解及对比--转

    http://www.jb51.net/article/100183.htm 接的隔离级别.它的语法如下: ? 1 SET [SESSION | GLOBAL] TRANSACTION ISOLATI ...

  9. mysql事务_事务隔离级别详解

    使用事务语法 1. 开启事务start transaction,可以简写为 begin 2. 然后记录之后需要执行的一组sql 3. 提交commit 4. 如果所有的sql都执行成功,则提交,将sq ...

随机推荐

  1. JDBC连接SQLSERVER

    package xhs;import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; im ...

  2. html页面展示Json样式

    一般有些做后台数据查询,要把后台返回json数据展示到页面上,如果需要展示样式更清晰.直观.一目了然,就要用到html+css+js实现这个小功能 一.css代码 pre {outline: 1px ...

  3. flask+APScheduler 任务调度,计划任务,定时任务

    from flask import Flask from flask_apscheduler import APScheduler # 引入APScheduler from test124 impor ...

  4. Apache 子项目 概述

    apache HTTP Server--------Web服务器(多用于静态网页,有负载均衡效果,可承受每天数百万人访问).apache Abdera>>>>>>& ...

  5. 关于hot miami的沙盒生存俯视角射击游戏

    一些关卡设计元素 撞门杀 扇形视角

  6. SQL2012 创建备份计划

    打开数据库,选择 管理 -> 新建维护计划,填写计划名称 修改计划参数 工具箱->备份数据库任务,拖到计划里 编辑任务 拖动清除数据库任务到计划 编辑清除任务 从备份任务到清除任务拖一个箭 ...

  7. 使用ALVideoPlayerSurface制作视频播放器

    头两天介绍了开源控件包alcinoe,现在利用其中的ALVideoPlayerSurface视频播放控件,实作一个视频播放器. 首先,建一个fmx项目,然后从组件面版,拖放一个TAlVideoPlay ...

  8. Linux C 文件操作函数(~上善止水~)

    翻翻笔记,整理一下 C 语言中的文件操作函数 ~~~~~~,多注意细节,maybe 细节决定成败~ 1. fopen /* fopen(打开文件) * * 相关函数 open,fclose * * 表 ...

  9. rem & em初探

    Rem为单位 CSS3的出现,他同时引进了一些新的单位,包括我们今天所说的rem.在W3C官网上是这样描述rem的——“font size of the root element” .下面我们就一起来 ...

  10. Java各种排序算法

      Java各种排序算法详解 排序大的分类可以分为两种:内排序和外排序.在排序过程中,全部记录存放在内存,则称为内排序,如果排序过程中需要使用外存,则称为外排序.下面讲的排序都是属于内排序. 内排序有 ...