关系代数和SQL语言应用:学生参加科研训练项目的数据库
简单粗暴的除法和减法哦!
5个小题,除法题目是肯定会考的(4分制)。把所有圈起来划重点,这是要用除法的!
5个小题,减法大概率也是要考要考滴(4分)。"没有"两个字圈起来,这是要用减法的。
关系代数优化(4分)。
关系代数优化的步骤。
step1:写出改写后的关系代数表达式。
step2:画初始优化树。
step3:选择下移优化,投影优化(保留关键性的1~2步)
step4:根据要求决定最后体现的是优化后的语法树还是优化后的表达式.
---------------------------------------------------------------------------------------------------------------------------------
学生参加科研训练项目的数据库包含如下关系模式:
学院(D)(学院代码Dno,学院名称Dname)
学生(S)(学号Sno,姓名Sname,性别Sex,联系方式Tel)
项目(P)(项目编号Pno,项目名Pname,立项年份Year,负责人Sno,级别level,资助金额Funding,学院代码Dno)
参与(S_P)(学号Sno,项目编号Pno,承担任务task)
题目重述分析:
学院(D)(学院代码Dno,学院名称Dname)
学生(S)(学号Sno,姓名Sname,性别Sex,联系方式Tel)
项目(P)(项目编号Pno,项目名Pname,立项年份Year,负责人Sno,级别level,资助金额Funding,学院代码Dno)
参与(S_P)(学号Sno,项目编号Pno,承担任务task)
从码的角度来分析呀:
项目和其他的3个表拥有很大的联系,它拥有两个外码。
用关系代数语言表达一些查询:
(1)查询参与过计算机学院2016年立项的所有国家级项目的学生姓名和联系方式。
分析:5个小题,除法题目是肯定会考的,要勾勾画画,看到"查询参与过计算机学院(Dname='计算机')2016年(Year='2016')立项的所有(除法运算)国家级(level='国家级')项目的学生姓名和联系方式。"的时候迅速捕捉到"所有"这个关键词,
毫无疑问,除法实锤了!
布局除法表达式嘤嘤:
(2)查询没有参加过任何项目的学生学号和姓名。
分析:5个小题,减法大概率也是要考要考滴。"没有"两个字圈起来,这是要用减法的。
简单粗暴的来点除法嘿嘿:
(3)查询至少参与过两个项目的学生姓名和联系方式。
分析:自连接是也。
(4)查询参与过"旅行足记"项目的学生学号和姓名。
(5)对查询"查询参与过"旅行足记"项目的学生学号和姓名。"进行优化,给出优化后的语法树。
分析:
关系代数优化的步骤。
step1:写出改写后的关系代数表达式。
step2:画初始优化树。
step3:选择下移优化,投影优化(保留关键性的1~2步)