InnoDB锁问题 & DB事务隔离级别
https://www.cnblogs.com/Katerina/p/11459135.html
数据库事务隔离级别:4 种     (http://www.cnblogs.com/fjdingsd/p/5273008.html)
read uncommitted  -->  read committed  --> repeatable read --> Serializable
   脏读             不可重复读           幻读
MySQL的默认隔离级别:Repeatable read。
大多数数据库的默认级别是 Read committed,比如 Sql Server , Oracle。
select @@tx_isolation; -- 查询当前的事务隔离级别
set session transaction isolation level repeatable read; -- 设置当前连接的事务隔离级别(临时更改)
注:
如果要永久更改事务隔离级别,则要在 mysql 的 my.ini 配置中设置
例如:transaction-isolation=Read-Committed
数据库的脏读、不可重复读、幻读以及不可重复读和幻读的区别(http://blog.csdn.net/stu_hsj/article/details/46603681)
脏读:
脏读又称无效数据读出。一个事务读取另外一个事务还没有提交的数据叫脏读。
例如:事务T1修改了一行数据,但是还没有提交,这时候事务T2读取了被事务T1修改后的数据,之后事务T1因为某种原因Rollback了,那么事务T2读取的数据就是脏的。
解决办法:把数据库的事务隔离级别调整到READ_COMMITTED
不可重复读:
不可重复读是指在同一个事务内,两个相同的查询返回了不同的结果。
例如:事务T1读取某一数据,事务T2读取并修改了该数据,T1为了对读取值进行检验而再次读取该数据,便得到了不同的结果。 解决办法:把数据库的事务隔离级别调整到REPEATABLE_READ
幻读:
例如:系统管理员A将数据库中所有学生的成绩从具体分数改为ABCDE等级,但是系统管理员B就在这个时候插入了一条具体分数的记录,当系统管理员A改结束后发现还有一条记录没有改过来,就好像发生了幻觉一样。这就叫幻读。
解决办法:把数据库的事务隔离级别调整到SERIALIZABLE_READ
对 REPEATABLE-READ 的测试:(MySQL)
参考:https://www.liaoxuefeng.com/wiki/1177760294764384/1245268672511968
CREATE TABLE `stu` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`name` varchar(255) DEFAULT NULL,
`age` int(11) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
+----+---------+------+
| id | name    | age  |
+----+---------+------+
|  1  | zhansan |   25   |
|  2  | lisi    |   18   |
+----+---------+------+

开两个 dos 窗口来测试:

REPEATABLE_READ 时,产生幻读测试:(MySQL)

<参考:http://www.cnblogs.com/jack204/archive/2012/06/09/2542940.html>
InnoDB行锁实现方式
InnoDB行锁是通过给索引上的索引项加锁来实现的,这一点MySQL与Oracle不同,后者是通过在数据块中对相应数据行加锁来实现的。InnoDB这种行锁实现特点意味着:只有通过索引条件检索数据,InnoDB才使用行级锁,否则,InnoDB将使用表锁!
由于MySQL的行锁是针对索引加的锁,不是针对记录加的锁,所以虽然是访问不同行的记录,但是如果是使用相同的索引键,是会出现锁冲突的。应用设计的时候要注意这一点。
如果出现死锁,可以用SHOW INNODB STATUS命令来确定最后一个死锁产生的原因。
共享锁(S):SELECT * FROM table_name WHERE ... LOCK IN SHARE MODE。
  排他锁(X):SELECT * FROM table_name WHERE ... FOR UPDATE。
用SELECT ... IN SHARE MODE获得共享锁,主要用在需要数据依存关系时来确认某行记录是否存在,并确保没有人对这个记录进行UPDATE或者DELETE操作。但是如果当前事务也需要对该记录进行更新操作,则很有可能造成死锁,对于锁定行记录后需要进行更新操作的应用,应该使用SELECT... FOR UPDATE方式获得排他锁。
给记录集显示加锁时,最好一次性请求足够级别的锁。比如要修改数据的话,最好直接申请排他锁,而不是先申请共享锁,修改时再请求排他锁,这样容易产生死锁;
<href:http://stackoverflow.com/questions/4034976/difference-between-read-commit-and-repeatable-read>
read commit 和 repeatable read的比较

InnoDB锁问题 & DB事务隔离级别的更多相关文章
- MySQL锁问题,事务隔离级别
		
未完待续... 概述 这里专门指的是InnoDB存储引擎的锁问题和事务隔离级别. ========================================================= 锁 ...
 - DB事务隔离级别
		
原创转载请注明出处:https://www.cnblogs.com/agilestyle/p/11393417.html 事务隔离级别 Note: Oracle默认的隔离级别是 READ COMMIT ...
 - SQL锁机制和事务隔离级别
		
摘自:http://www.cnblogs.com/haiyang1985/archive/2009/02/27/1399641.html 锁机制 NOLOCK和READPAST的区别. 1. ...
 - Mysql InnoDB的四个事务隔离级别和(分别逐级解决的问题)脏读,不可重复读,虚读
		
MySqlInnoDB的事务隔离级别有四个:(默认是可重复读repeatable read) 未提交读 read uncommit : 在另一个事务修改了数据,但尚未提交,在本事务中SELECT语句可 ...
 - 面试突击84:Spring 有几种事务隔离级别?
		
Spring 中的事务隔离级别和数据库中的事务隔离级别稍有不同,以 MySQL 为例,MySQL 的 InnoDB 引擎中的事务隔离级别有 4 种,而 Spring 中却包含了 5 种事务隔离级别. ...
 - Innodb中的事务隔离级别和锁的关系
		
前言: 我们都知道事务的几种性质,数据库为了维护这些性质,尤其是一致性和隔离性,一般使用加锁这种方式.同时数据库又是个高并发的应用,同一时间会有大量的并发访问,如果加锁过度,会极大的降低并发处理能力. ...
 - Innodb中的事务隔离级别和锁的关系(转)
		
原文:http://tech.meituan.com/innodb-lock.html 前言: 我们都知道事务的几种性质,数据库为了维护这些性质,尤其是一致性和隔离性,一般使用加锁这种方式.同时数据库 ...
 - MySQL InnoDB中的事务隔离级别和锁的关系
		
前言: 我们都知道事务的几种性质,数据库为了维护这些性质,尤其是一致性和隔离性,一般使用加锁这种方式.同时数据库又是个高并发的应用,同一时间会有大量的并发访问,如果加锁过度,会极大的降低并发处理能力. ...
 - 重新学习MySQL数据库9:Innodb中的事务隔离级别和锁的关系
		
重新学习MySQL数据库9:Innodb中的事务隔离级别和锁的关系 Innodb中的事务隔离级别和锁的关系 前言: 我们都知道事务的几种性质,数据库为了维护这些性质,尤其是一致性和隔离性,一般使用加锁 ...
 
随机推荐
- Linux mail命令使用和sendmail配置
			
linux mail 命令参数: 使用mail发邮件时,必须先将sendmail服务启动. mail –s “邮件主题” –c”抄送地址” –b “密送地址” -- -f 发送人邮件地址 –F 发件人 ...
 - hbase源码系列(十二)Get、Scan在服务端是如何处理?
			
继上一篇讲了Put和Delete之后,这一篇我们讲Get和Scan, 因为我发现这两个操作几乎是一样的过程,就像之前的Put和Delete一样,上一篇我本来只打算写Put的,结果发现Delete也可以 ...
 - .net 4中使用 dynamic,将json字符串转成对象的 万能方法。
			
在.net 4中增加了对弱类型的支持.为和弱类型的对象进行数据交换提供了方法.我们常常会遇到将json字符串转成对象的情景,虽然可以使用 JavaScriptSerializer 或者 DataCon ...
 - 引入css少引入了rel="stylesheet" 这行代码。导致整个页面空白、
			
忘记引入rel="stylesheet" 如下: <link href="css/swiper-3.3.1.min.css" /> 这样使得整个页 ...
 - Java设计模式(8)组合模式(Composite模式)
			
Composite定义:将对象以树形结构组织起来,以达成“部分-整体” 的层次结构,使得客户端对单个对象和组合对象的使用具有一致性. Composite比较容易理解,想到Composite就应该想到树 ...
 - Java虚拟机(JVM)体系结构概述及各种性能参数优化总结
			
转自:http://blog.csdn.net/zhongwen7710/article/details/39213377 第一部分:相关的概念 数据类型 Java虚拟机中,数据类型可以分为两类:基本 ...
 - 【转】VSCode Web开发插件
			
Web开发必备插件 1.Beautify - HTML.CSS.JS.JSON语法高亮 语法高亮,你懂的. Beautify 2.Auto rename tag - 自动重命名标签 在HTML, ...
 - 对C语言中指针的入门理解
			
通过一个例子引出对指针的概念理解 1,例子 #include<stdio.h> int main(void) { ; //小张的身高 ; //小李的身高 ; //小王的身高 int *xi ...
 - 【Hibernate步步为营】--最后的集合映射
			
上篇文章具体讨论了组合对象映射的原理.它事实上指的是怎样将对象模型中的组合关系映射到关系模型中,它是通过使用Hibernate提供的<component>标签来实现的,并须要在该标签中加入 ...
 - [深入理解Android卷一全文-第三章]深入理解init
			
因为<深入理解Android 卷一>和<深入理解Android卷二>不再出版,而知识的传播不应该因为纸质媒介的问题而中断,所以我将在CSDN博客中全文转发这两本书的全部内容. ...