第五章 数据库设计和事务 ② 代码

导读:本篇文章讲解 第五章 数据库设计和事务 ② 代码,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

事务管理

数据库事务的原理

#创建银行帐号表
create table bank
(
		bid int primary key auto_increment,
		account varchar(20),
		money int
);

select * from bank;

insert into bank
(account,money)
values
('张三',10000),
('李四',10000);

select * from bank;

#手动开启事务
start transaction;

update bank
	set money=money-1000
where account='张三';

select * from bank;

#突然出错
#回滚事务
#rollback;  #只能执行一次,回滚之后手动事务就结束了。

select * from bank;

update bank
	set money=money+1000
where account='李四';

#手动提交事务
commit;

select * from bank;

代码仅供参考

MySQL事务隔离级别

1.Read Uncommitted(未提交读) ru


#事务a
#设置事务为未提交读
set session transaction isolation level read uncommitted;
#开始手动事务
start transaction;
#更新数据
update classInfo
set className='111'
where classId=1;
#回滚事务
rollback;

select * from classInfo


#事务b:在另外一个脚本中运行
set session transaction isolation level read uncommitted;
select * from classInfo where classId=1

2.Read Committed(提交读)rc


#事务a
#设置事务隔离级别为提交读
set session transaction isolation level read committed;
#开启手动事务
start transaction;
#在事务中第一次查询数据
select * from classInfo where classId = 1;
#在事务中第二次查询数据
select * from classInfo where classId =1;
#提交事务
commit;


#事务b(在另外一个脚本中执行)
set session transaction isolation level read committed;
start transaction;
update classInfo
set className='111'
where classId = 1
commit;

3.Repeatable Read(可重复读)rr


#事务a
#设置事务隔离级别为可重复读
set session transaction isolation level repeatable read;
#开启手动事务
start transaction;
#查询编号为10的班级
select * from classInfo where classId=10;
#插入班级编号为10的班级
insert into classInfo
(classid,className)
values
(10,'AAA10');
#提交事务
commit;

select * from classInfo

#事务b(在另外一个脚本中上运行)
set transaction isolation level repeatable read;


#开启手动事务
start transaction;
#插入编号为10的班级
insert into classInfo
(classId,className)
values
(10,'AAA10');
#提交事务
commit;

4.Serializable(可串行化)

#事务a
#设置事务隔离级别为可重复读
set session transaction isolation level serializable;
#开启手动事务
start transaction;
#查询编号为10的班级
select * from classInfo where classId=10;
#插入班级编号为10的班级
insert into classInfo
(classid,className)
values
(10,'AAA10');
#提交事务
commit;

#事务b(在另外一个脚本中上运行)
set transaction isolation level serializable;


#开启手动事务
start transaction;
#插入编号为10的班级
insert into classInfo
(classId,className)
values
(10,'AAA10');
#提交事务
commit;

问题

1.脏读

#解决脏读问题,提升数据库库隔离级别

#事务a
#设置事务为提交读
set session transaction isolation level read committed;
#开始手动事务
start transaction;
#更新数据
update classInfo
set className='111'
where classId=1;
#回滚事务
rollback;

select * from classInfo
#将事务隔离级别提升为提交读

#事务b:在另外一个脚本中运行
set session transaction isolation level read committed;
select * from classInfo where classId=1

2.幻读

#事务a
#设置事务隔离级别为提交读
set session transaction isolation level repeatable read;
#开启手动事务
start transaction;
#在事务中第一次查询数据
select * from classInfo where classId = 1;
#在事务中第二次查询数据
select * from classInfo where classId =1;
#提交事务
commit;

select * from classInfo;
#事务b(在另外一个脚本中执行)
set session transaction isolation level repeatable read;
start transaction;
update classInfo
set className='111'
where classId = 1
commit;

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之家整理,本文链接:https://www.bmabk.com/index.php/post/118102.html

(0)
seven_的头像seven_bm

相关推荐

发表回复

登录后才能评论
极客之家——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!