首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > Mysql >

MySQL事宜隔离级别详解[转]

2013-03-25 
MySQL事务隔离级别详解[转]?下面,将利用MySQL的客户端程序,分别测试几种隔离级别。测试数据库为test,表为tx

MySQL事务隔离级别详解[转]

?

下面,将利用MySQL的客户端程序,分别测试几种隔离级别。测试数据库为test,表为tx;表结构:

id????????????????????????????? int

num

????????????????????????????? int

两个命令行客户端分别为A,B;不断改变A的隔离级别,在B端修改数据。

(一)、将A的隔离级别设置为read uncommitted(未提交读)

?在B未更新数据之前:

客户端A:MySQL事宜隔离级别详解[转]

B更新数据:

客户端B:

MySQL事宜隔离级别详解[转]

客户端A:

MySQL事宜隔离级别详解[转]

??????? 经过上面的实验可以得出结论,事务B更新了一条记录,但是没有提交,此时事务A可以查询出未提交记录。造成脏读现象。未提交读是最低的隔离级别。

(二)、将客户端A的事务隔离级别设置为read committed(已提交读)

?在B未更新数据之前:

客户端A:

MySQL事宜隔离级别详解[转]

B更新数据:

客户端B:

MySQL事宜隔离级别详解[转]

客户端A:

MySQL事宜隔离级别详解[转]

?????? 经过上面的实验可以得出结论,已提交读隔离级别解决了脏读的问题,但是出现了不可重复读的问题,即事务A在两次查询的数据不一致,因为在两次查询之间事务B更新了一条数据。已提交读只允许读取已提交的记录,但不要求可重复读。

(三)、将A的隔离级别设置为repeatable read(可重复读)

?在B未更新数据之前:

B更新数据:

客户端B:

MySQL事宜隔离级别详解[转]

客户端A:

MySQL事宜隔离级别详解[转]

B插入数据:

客户端B:

MySQL事宜隔离级别详解[转]

客户端A:

MySQL事宜隔离级别详解[转]

?????? 由以上的实验可以得出结论,可重复读隔离级别只允许读取已提交记录,而且在一个事务两次读取一个记录期间,其他事务部的更新该记录。但该事务不要求与其他事务可串行化。例如,当一个事务可以找到由一个已提交事务更新的记录,但是可能产生幻读问题(注意是可能,因为数据库对隔离级别的实现有所差别)。像以上的实验,就没有出现数据幻读的问题。

(四)、将A的隔离级别设置为?可串行化?(Serializable)

A端打开事务,B端插入一条记录

事务A端:

MySQL事宜隔离级别详解[转]

事务B端:

MySQL事宜隔离级别详解[转]

因为此时事务A的隔离级别设置为serializable,开始事务后,并没有提交,所以事务B只能等待。

事务A提交事务:

事务A端

MySQL事宜隔离级别详解[转]

事务B端

MySQL事宜隔离级别详解[转]

??????

?????????serializable完全锁定字段,若一个事务来查询同一份数据就必须等待,直到前一个事务完成并解除锁定为止?。是完整的隔离级别,会锁定对应的数据表格,因而会有效率的问题。

热点排行