数据库系统期末习题解析:SQL与关系代数操作

需积分: 0 16 下载量 32 浏览量 更新于2024-08-03 1 收藏 12KB DOCX 举报
"广工数据库系统期末练习题,涉及SQL语句编写、关系代数表达式及数据库设计。" 在这些题目中,我们看到一系列关于数据库管理和查询的问题,主要涵盖SQL语言、关系代数和数据库规范化理论。让我们逐一分析: 1. 题目要求查询年龄低于作者平均年龄的所有作者及其对应的书名和出版社。这涉及到聚合函数AVG()的使用,以及JOIN操作。SQL语句可能如下: ```sql SELECT a.作者名, t.书名, t.出版社 FROM 作者 a JOIN 图书 t ON a.作者编号 = t.作者编号 WHERE a.年龄 < (SELECT AVG(年龄) FROM 作者) ``` 2. 设计财务处收学费的数据库,我们需要创建两个表`学生`和`收费`,并指定主键和外键。SQL语句定义如下: ```sql CREATE TABLE 学生 ( 学号 CHAR PRIMARY KEY, 姓名 CHAR, 专业 CHAR, 入学日期 DATE ); CREATE TABLE 收费 ( 学年 INT, 学号 CHAR, 学费 DECIMAL, 书费 DECIMAL, 总金额 DECIMAL, FOREIGN KEY (学号) REFERENCES 学生(学号) ); ``` 这里,`学号`是`学生`表的主键,同时也是`收费`表的外键。 3. 关系代数表达式的题目主要测试对关系操作的理解。例如: (1) 检索“英语”专业学生所学课程信息,可以用投影和连接操作: $$\pi_{学号,姓名,课程名,分数}(\sigma_{专业='英语'}(学生) \Join 学习)$$ (2) 检索“数据库原理”课程成绩高于90分的学生信息: $$\pi_{学号,姓名,专业,分数}(\sigma_{名称='数据库原理' \land 分数>90}(学习) \Join 学生)$$ 4. SQL语言实现的题目与关系代数类似,例如: (5) 删除所有学号在“学习”表中没有对应“C135”课程记录的学生信息: ```sql DELETE FROM 学生 WHERE 学号 NOT IN (SELECT 学号 FROM 学习 WHERE 课程号 = 'C135') ``` (6) 查询至少学过“C135”和“C219”课程的学生信息: ```sql SELECT 学号, 姓名, 专业 FROM 学生 WHERE 学号 IN (SELECT 学号 FROM 学习 WHERE 课程号 IN ('C135', 'C219') GROUP BY 学号 HAVING COUNT(*) = 2) ``` (7) 删除有过0分成绩的学生: ```sql DELETE FROM 学生 WHERE 学号 IN (SELECT 学号 FROM 学习 WHERE 分数 = 0) ``` (8) 定义视图AAA: ```sql CREATE VIEW AAA AS SELECT 学号, 姓名, 课程号, 分数 FROM 学生 s JOIN 学习 l ON s.学号 = l.学号 WHERE s.专业 = '英语' ``` 5. 对于关系模式R,我们需要找出其函数依赖、候选键、范式级别,并进行规范化。具体分析和答案不在SQL或关系代数的范畴,而是数据库理论的内容,需要对数据库设计有深入理解。 这些问题覆盖了数据库管理的关键方面,包括数据查询、表结构设计、视图创建、数据更新以及数据库规范化。解决这些问题需要扎实的SQL基础和对关系模型的理解。