某企业信息系统的部分关系模式及属性说明如下: (1)员工关系模式:员工(员工编

考试题库2022-08-02  68

问题 某企业信息系统的部分关系模式及属性说明如下:(1)员工关系模式:员工(员工编号,姓名,部门,工资,职务,教育水平),其中员工编号是主键,部门是外键,参照部门关系模式的部门编号属性。(2)部门关系模式:部门(部门编号,部门名称,经理),其中部门编号是主键,经理是外键,参照员工关系模式的员工编号属性。(3)项目关系模式:项目(项目编号,项目名称,所属部门,负责人),其中项目编号是主键,所属部门和负责人是外键,分别参照部门关系模式和员工关系模式的部门编号和员工编号属性。(4)员工项目关系模式:员工项目(员工编号,项目编号),其中员工编号和项目编号是主键,同时员工编号和项目编号也是外键,分别参照员工关系模式的员工编号和项目关系模式的项目编号。【问题1】(2分)假设定义员工关系模式时,没有定义主键和外键。请用SQL语句补充定义员工关系模式的实体完整性约束和参照完整性约束。(a) ;(b) ;【问题2】(13分)请将下列SQL查询语句补充完整。(1)查询平均工资(不包含职务为经理的员工)超过3000的部门的编号,部门名称及其平均工资,并按平均工资从高到低排序。SELECT部门编号,部门名称,(c)  AS平均工资FROM员工,部门WHERE  (d)GROUP BY  (e)HAVING   (f)(g);(2)查询工资大于全体员工平均工资的员工编号,姓名和工资。SELECT员工编号,姓名,工资FROM员工WHERE  (h);(3)查询没有承担任何项目的部门编号和部门名称。SELECT部门编号,部门名称FROM部门WHERE (i)  (SELECT.FROM项目WHERE  (i)  );(4)查询研发部所有员工的员工编号和教育水平,若教育水平大于20,则输出研究生;若教育水平小于等于20,并大于16,则输出本科生;否则输出其他。SELECT员工编号,CASEWHEN教育水平>20 THEN‘研究生’(k)(l)ENDFROM员工,部门WHERE (m)  ;(5)查询部门名称不以“处”结尾的部门编号和部门名称。SELECT部门编号,部门名称FROM部门WHERE部门名称 (n) ;

选项

答案

解析 【问题1】(2分)
(a) ALTER TABLE员工ADD CONSTRAINT PK员工  PRIMARY KEY(员工编号) (其中PK_员工可以为任何有效的命名)
(b)ALTER  TABLE员工ADD CONSTRAINT FK员工  FOREIGN KEY(部门) REFERENCES部门(部门编号)(其中FK员工可以为任何有效的命名)
【问题2】(13分)
(1)(c)AVG(工资)
(d)员工,部门=部门.部门编号AND职务<>’经理’
(e)部门编号,部门名称
(f) AVG(工资)>3000
(g) ORDER BY3 DESC或ORDER BY平均工资DESC
(2)(h)工资> (SELECT AVG(工资)FROM员工)(2分)
(3)(i) NOTEXISTS
(j)部门编号=所属部门
(4) (k) WHEN教育水平<=20 AND教育水平>16 THEN’本科生’
(l) ELSE’其他’
(m)员工.部门=部门.部门编号AND部门名称=’研发部’
(5)(m)NOT LIKE ’%处’
转载请注明原文地址:https://tihaiku.com/congyezige/2419752.html

最新回复(0)