数据库——习题

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;

相关推荐
兜兜风d'31 分钟前
redis字符串命令
数据库·redis·缓存
忧郁的蛋~2 小时前
EFcore查询a表中符合b表列的值
数据库
xwz小王子2 小时前
ManipulationNet:开启真实世界机器人操作基准测试新时代
数据库·机器人
咯哦哦哦哦2 小时前
关于QT 打印中文 乱码问题
java·数据库·qt
野犬寒鸦2 小时前
从零起步学习Redis || 第十二章:Redis Cluster集群如何解决Redis单机模式的性能瓶颈及高可用分布式部署方案详解
java·数据库·redis·后端·缓存
ShooterJ3 小时前
Mysql小表驱动大表优化原理
数据库·后端·面试
程序员三明治3 小时前
【MyBatis从入门到入土】告别JDBC原始时代:零基础MyBatis极速上手指南
数据库·mysql·mybatis·jdbc·数据持久化·数据
cookqq3 小时前
MongoDB源码delete分析oplog:从删除链路到核心函数实现
数据结构·数据库·sql·mongodb·nosql
瀚高PG实验室5 小时前
HGDB集群(安全版)repmgr手动切换主备库
java·数据库·安全·瀚高数据库
mit6.8245 小时前
[C# starter-kit] Domain Entities | `AuditableEntity`基类 | 跟踪变化 | 软删除
数据库·microsoft·c#