事务
本篇文章描述了数据库事务隔离级对锁影响通过对比事务隔离级0和1理解锁和脏读关系
实验内容:分别设置0和1级隔离级执行两个区别但又有相关事务本实验环境如下:
1、 有权访问用户数据库(在此是aca_database)和对数据库表有修改和查询权限
2、 数据库中有表auths包含salary列(数据类型是money)有定数据量(在此有1万行)
步骤:
1、 如在同台机器可分别执行两次“SQL Advantage”分别用合法帐号登录准备各自执行个事务
2、 在各自界面打开用户数据库aca_database设置隔离级为1(此亦为缺省值):
transaction isolation level 1查看当前隔离级别用select @@isolation
3、 执行第个事务前两句暂不执行后面提交或回滚
begin transaction
update auths salary=salary+100
commit transaction
(rollback transaction)
4、 执行第 2个事务 select sum(salary) from auths
5、 第个事务正常执行结束但只在内存缓冲区完成修改事务并没有真正结束相应也不释放锁第 2个事务处于等待状态可执行sp_lock和sp_who命令查看
6、 执行第3步中提交或回滚命令第 2个事务得到执行
7、 改变事务隔离级为0重复执行3-4步第个事务没有任何变化第 2个事务很快出来根据第个事务修改数据而成结果似乎在执行响应上并不受第个事务影响
8、 重复第6步结束
通过上面实验我们知道:
1、 隔离级0时事务允许脏读隔离级1时事务不允许脏读而只是等待前个修改事务真正结束并释放锁
2、 隔离级为0时如果在修改事务最后是回滚操作则查询读事务将不能读到正确数据
3、 在确信事务中没有回滚操作可能并要求更高执行效率和并行性只有这时可考虑设置隔离级为0
最新评论