博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
2014/7/27------数据库的隔离性
阅读量:6150 次
发布时间:2019-06-21

本文共 1381 字,大约阅读时间需要 4 分钟。

演示不同隔离级别下的并发问题

1.当把事务的隔离级别设置为read uncommitted ,会引发脏读。不可反复读。虚读

A窗体

set transaction isolation  level  read uncommitted;

start transaction;

select * from account;

=======这个时候发现aaa的账户是1000元,转到B窗体

select * from acount where name=='aaa';

=======发现aaa的账户多了100元。这个时候a窗体读到的数据时b窗体未提交的数据(脏读);

B窗体

start transaction;(有这句话。不写commit语句,数据是不会提交到数据库的)

update account set money=money+100  where name='aaa';

------不要提交。转到A窗体查询

2..当把事务的隔离级别设置为read committed ,会引发不可反复读,虚读,但可避免脏读;

A窗体

set transaction isolation  level  read committed;

start transaction;

select * from account;

=======这个时候发现aaa的账户是1000元。转到B窗体

select * from acount where name=='aaa';

=======发现aaa的账户多了100元。这个时候a窗体读到了别的事务提交的数据,两次读取到的是不同的数据(不可反复读);

 

B窗体

start transaction;

update account set money=money+100  where name='aaa';

commit;

-----转到a窗体

3.当把事务的隔离级别设置为repeatable read(mysql 默认级别) ,会引发虚读,但可避免脏读,不可反复读。

A窗体:

set transaction isolation level repeatable read;

start transaction ;

select * from account;

=======发现有4条记录,转到b窗体

select * from account;

========可能发现有5条记录,这时候发生了a读取到另外一个事务插入的数据(虚读)

B窗体

start transaction;

insert  into acount(name,money) values('ggg',1000);

commit;

-------转到a窗体

4.当把事务的隔离级别设置为Serializable ,会避免全部的问题。

A窗体:

set transaction isolation level repeatable read;

start transaction ;

select * from account;

=======发现有4条记录,转到b窗体

B窗体

start transaction;

insert  into acount(name,money) values('ggg',1000);

-------发现不能插入。仅仅能等待a结束事务才干插入

转载地址:http://xzwfa.baihongyu.com/

你可能感兴趣的文章
Javascript Ajax 异步请求
查看>>
DBCP连接池
查看>>
cannot run programing "db2"
查看>>
mysql做主从relay-log问题
查看>>
Docker镜像与容器命令
查看>>
批量删除oracle中以相同类型字母开头的表
查看>>
Java基础学习总结(4)——对象转型
查看>>
BZOJ3239Discrete Logging——BSGS
查看>>
SpringMVC权限管理
查看>>
spring 整合 redis 配置
查看>>
redhat6.1下chrome的安装
查看>>
cacti分组发飞信模块开发
查看>>
浅析LUA中游戏脚本语言之魔兽世界
查看>>
飞翔的秘密
查看>>
Red Hat 安装源包出错 Package xxx.rpm is not signed
查看>>
编译安装mysql-5.6.16.tar.gz
查看>>
类与成员变量,成员方法的测试
查看>>
活在当下
查看>>
每天进步一点----- MediaPlayer
查看>>
PowerDesigner中CDM和PDM如何定义外键关系
查看>>