java面试题网

普通会员

183

帖子

7

回复

95

积分

楼主
发表于 2019-08-26 15:24:39 | 查看: 5109| 回复: 0

mysql事务的隔离级别

mysql事务的隔离级别

隔离级别

  • 事务的隔离级别决定了事务之间可见的级别。
  • 当多个客户端并发地访问同一个表时,可能出现下面的一致性问题:脏读取(Dirty Read)

一个事务开始读取了某行数据,但是另外一个事务已经更新了此数据但没有能够及时提交,这就出现了脏读取。

  • 不可重复读(Non-repeatable Read)

在同一个事务中,同一个读操作对同一个数据的前后两次读取产生了不同的结果,这就是不可重复读。

  • 幻像读(Phantom Read)

幻像读是指在同一个事务中以前没有的行,由于其他事务的提交而出现的新行。

 

四个隔离级别

  • InnoDB 实现了四个隔离级别,用以控制事务所做的修改,并将修改通告至其它并发的事务:读未提交(READ UMCOMMITTED)

允许一个事务可以看到其他事务未提交的修改

  • 读已提交(READ COMMITTED)

允许一个事务只能看到其他事务已经提交的修改,未提交的修改是不可见的

  • 可重复读(REPEATABLE READ)

确保如果在一个事务中执行两次相同的SELECT语句,都能得到相同的结果,不管其他事务是否提交这些修改。 (银行总账)

该隔离级别为InnoDB的缺省设置

  • 串行化(SERIALIZABLE) 【序列化】

将一个事务与其他事务完全地隔离。

例:A可以开启事物,B也可以开启事物

A在事物中执行DML语句时,未提交

B不以执行DML,DQL语句

 

隔离级别与一致性问题的关系

mysql事务的隔离级别_www.wityx.com

设置服务器缺省隔离级别

通过修改配置文件设置

  • 可以在my.ini文件中使用transaction-isolation选项来设置服务器的缺省事务隔离级别
  • 该选项值可以是: READ-UNCOMMITTED READ-COMMITTED REPEATABLE-READ SERIALIZABLE

例如:

[mysqld]

transaction-isolation = READ-COMMITTED

通过命令动态设置隔离级别

  • 隔离级别也可以在运行的服务器中动态设置,应使用SET TRANSACTION ISOLATION LEVEL语句
  • 其语法模式为:

SET [GLOBAL | SESSION] TRANSACTION ISOLATION LEVEL

其中的 可以是:

  • READ UNCOMMITTED READ COMMITTED REPEATABLE READ SERIALIZABLE
  • 例如: SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;

 

隔离级别的作用范围

  • 事务隔离级别的作用范围分为两种: 全局级:对所有的会话有效 会话级:只对当前的会话有效

例如,设置会话级隔离级别为READ COMMITTED :

mysql> SET TRANSACTION ISOLATION LEVEL READ COMMITTED;

或:

mysql> SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;

  • 设置全局级隔离级别为READ COMMITTED :

mysql> SET GLOBAL TRANSACTION ISOLATION LEVEL READ COMMITTED;

 

查看隔离级别

  • 服务器变量tx_isolation(包括会话级和全局级两个变量)中保存着当前的会话隔离级别。
  • 为了查看当前隔离级别,可访问tx_isolation变量:

查看会话级的当前隔离级别:

mysql> SELECT @@tx_isolation;

或:

mysql> SELECT @@session.tx_isolation;

查看全局级的当前隔离级别:

mysql> SELECT @@global.tx_isolation;

 

并发事务与隔离级别示例

会话一

会话二

mysql> prompt s1>

mysql> use bjpowernode

s1>use bjpowernode

mysql> prompt s2>

s1>create table tx (

id int(11),

num int (10)

);

s1>set global transaction isolation level read uncommitted;

s1>start transaction;

s2>start transaction;

s1>insert into tx values (1,10);

s2>select * from tx;

s1>rollback;

s2>select * from tx;

read uncommitted(未提交读) --脏读(Drity Read):

read committed(已提交读)

会话一

会话二

s1> set global transaction isolation level read committed;

s1>start transaction;

s2>start transaction;

s1>insert into tx values (1,10);

s1>select * from tx;

s2>select * from tx;

s1>commit;

s2>select * from tx;

repeatable read(可重复读)

会话一

会话二

s1> set global transaction isolation level repeatable read;

s1>start transaction;

s2>start transaction;

s1>select * from tx;

s1>insert into tx values (1,10);

s2>select * from tx;

s1>commit;

s2>select * from tx;


文章来自www.wityx.com,转载请注明出处!原文地址http://www.wityx.com/post/1074_1_1.html


java面试题交流群:327440556

上一篇:mysql索引 下一篇:mysql自动提交模式
您需要登录后才可以回帖 登录 | 立即注册

java面试题网www.wuliaokankan.cnjava建站系统提供技术支持V2.1 网站地图 © 2016-2018