关系代数和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步)

 

step4:根据要求决定最后体现的是优化后的语法树还是优化后的表达式.

 

 

 

解:

 

 

 

 

 

 

 

------------------------------------------------------------------------------------------------------------------------------

 

用SQL完成如下查询:

 

Continue------------

--------------------------------------------------------------------------------------------------------------

今天来填坑了23333:

 

 

 

 

 

 

posted @ 2020-03-18 17:52  龙龙666666  阅读(624)  评论(4编辑  收藏  举报