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;