数据库——习题

1. (其它, 40分)

考虑如下所所示的日志记录:

|----|------------|
| 序号 | 日志 |
| 1 | T1:开始 |
| 2 | T1:写A,A=20 |
| 3 | T2:开始 |
| 4 | T2:写B,B=19 |
| 5 | T1:写C,C=10 |
| 6 | T1:提交 |
| 7 | T2:写C,C=15 |
| 8 | T3:开始 |
| 9 | T3:写A,A=15 |
| 10 | T2:回滚 |
| 11 | T3:写B,B=8 |
| 12 | T4:开始 |
| 13 | T3:提交 |
| 14 | T4:写C,C=16 |

(1)如果系统故障发生在14之后,说明哪些事务需要重做,哪些事务需要回滚。

(2)如果系统故障发生在10之后,说明哪些事务需要重做,哪些事务需要回滚。

(3)如果系统故障发生在9之后,说明哪些事务需要重做,哪些事务需要回滚。

(4)如果系统故障发生在7之后,说明哪些事务需要重做,哪些事务需要回滚。

(40.0分)

(1)T1、T3事务需要重做;T4事务需要回滚;

(2)T1事务需要重做;T3事务需要回滚;

(3)T1事务需要重做;T2、T3事务需要回滚;

(4)T1事务需要重做;T2事务需要回滚;

2. (其它, 60分)

考虑上题所示的日志记录,假设开始时A=0、B=10、C=100:

(1)写出系统故障发生在14之后,写出系统恢复后A、B、C的值;

(2)写出系统故障发生在12之后,写出系统恢复后A、B、C的值;

(3)写出系统故障发生在10之后,写出系统恢复后A、B、C的值;

(4)写出系统故障发生在9之后,写出系统恢复后A、B、C的值;

(5)写出系统故障发生在7之后,写出系统恢复后A、B、C的值;

(6)写出系统故障发生在5之后,写出系统恢复后A、B、C的值.

(60.0分)

(1)A=15,B=8,C=10;

(2)A=20,B=10,C=10;

(3)A=20,B=10,C=10;

(4)A=20,B=10,C=10;

(5)A=20,B=10,C=10;

(6)A=0,B=10,C=100;

相关推荐
曹牧7 小时前
Oracle:前缀匹配之REGEXP_LIKE
数据库·oracle
暴躁小师兄数据学院10 小时前
【AI大数据工程师特训笔记】第05讲:关联查询
数据库·sql·oracle
倔强的石头_10 小时前
《Kingbase护城河》——跨平台环境下的数据库联调实战
数据库
lzhdim10 小时前
SQL 入门 17:MySQL 数据类型:从字符串到 JSON 的全面解析
数据库·sql·mysql·json
杨云龙UP10 小时前
Oracle RAC / ODA 生产环境指定 PDB 启动 SOP
linux·运维·数据库·oracle
kingwebo'sZone10 小时前
在Cent上安装Mysql 8.0的遇到的问题和解决办法
数据库·mysql·adb
幽络源小助理11 小时前
最新知识付费系统网站源码 PC+H5双端 附安装教程 – 幽络源源码网
大数据·数据库
小白考证进阶中11 小时前
Oracle OCP证书报考&考试全指南
数据库·oracle·oracle ocp·ocp认证·oracle认证·甲骨文认证·oracle ocp题库
Leon-Ning Liu12 小时前
【真实经验分享】 ORA-600 [qesmaGetTblSeg1]
数据库·oracle
与数据交流的路上12 小时前
MySQL 优化 -- 相关
数据库·mysql