学校学生选修课程,经简化得到的数据项列出如下:学生号s CHAR(6),学生姓名xm CHAR(8),课程号c CHA
学校学生选修课程,经简化得到的数据项列出如下:
学生号s CHAR(6),学生姓名xm CHAR(8),课程号c CHAR(3),课程名称cname CHAR (20),成绩 grade NUMBER。
并确定以学生(student)信息,课程(course)信息实体,它们通过“选课”(sc)联系起来。
数据库概念设计的只包含主键属性的简化E-R图如下:
要求;
(1)设计数据库的逻辑结构设计:给出相应的表名、表的属性名(数据类型可省)、主键。
(2)给出选修了课程号为"C02"的学生姓名的SQL查询语句。
(3)给出三种等价的关系代数表达式来完成上述查询。并从查询优化的角度说明哪一种关系代数表达式查询效率最高?并说明在此查询优化的基础上,对哪些字段建立索引可提高查询效率?
正确答案:数据库的逻辑结构设计:student(s#xm)主键:s#course(c#cname)主键:c#sc(s#c#grade)主键;s#c#(2)SELECT student.xm FROM student sc WHERE student. s#=sc. s# AND sc. c#='CO2';(3)系统可以用三种等价的关系代数表达式来完成上述查询。第一种;πxm(σstudent. s#=sc. s# ∧sc. c#='C02'(student×sC))执行的步骤是:首先计算student和sc
词条内容仅供参考,如果您需要解决具体问题
(尤其在法律、医学等领域),建议您咨询相关领域专业人士。
