参考答案:
【问题1】
(a)REFERENCES emp (Eno)
(b)REFERENCES company (Cno)
(c)CHECK(Salary>=1500)
(d)(Cno,Eno)
【问题2】
(e)View FemaleEMP
(f)Sex=’女’ AND EMP.Eno=WORKS.Eno AND COMPANY.Cno= WORKS.Cno
(g)TRIGGER
(h)UPDATE OF Title
(i)Salary=Salary_value(nrow.Eno)
(j)Eno=nrow.Eno
【问题3】
(k)COMPANY.Cno,Cname
(l)COUNT(*)>=ALL
(m)NOT IN
(n) COMPANY,WORKS
(o) COMPANY.Cno= WORKS.Cno
详细解析:
本题考查 SQL 语句的应用。
此类题目要求考生掌握 SQL 语句的基本语法和结构,认真阅读题目给出的关系模式,针对题目的要求具体分析并解答。本试题已经给出了 3 个关系模式,需要分析每个实体的属性特征及实体之间的联系,补充完整 SQL 语句。【问题1】
由题目说明可知, Eno 和 Cno 两个属性组合是 WORKS 关系表的主键,所以在 PRIMARY KEY 后填的应该是 (Eno,Cno) 组合; Eno 和 Cno 分别作为外键引用到 EMP 和 COMPANY 关系表的主键,因此需要用 REFERENCES 对这两个属性进行外键约束:
由"工资不能低于 1500 元"的要求,可知需要限制账户余额属性值的范围,通过CHECK约束来实现。从上述分析可知,完整的SQL 语句如下:
CREATE TABLE WORKS (
Eno CHAR (10) REFERENCES EMP(Eno) ,
Cno CHAR(4) REFERENCES COMPANY(Cno) ,
Salary int CHECK(Salary >=1500),
PRIMARY KEY (Eno,Cno) ,
);
【问题 2 】
(1)创建视图需要通过 CREATE VIEW 语句来实现,由题目可知视图的属性有 (Eno, Ename,Cno,Cname,Salary); 通过公共属性列 Eno 和 Cno 对使用的三个基本表进行连接: 由于只创建女员工的视图,所以还要在 WHERE 后加入 "Sex='女'"的条件。从上分析可 见,完整的 SQL 语句如下:
CREATE VIEW FemaleEMP(Eno ,Ename ,Cno ,Cname ,Sa1ary)
AS
SELECT EMP.Eno ,Ename ,COMPANY.Cno ,Cname,Sa1ary
FROM EMP ,COMPANY ,WORKS
WHERE EMP.Eno = WORKS.Eno AND COMPANY.Cno = WORKS.Cno AND Sex=‘女’;
(2)创建触发器可通过 CREATE TRIGGER 语句实现,要求考生掌握触发器的基本 语法结构。按照问题要求,在工资关系中更新职工职称级别时触发器应自动执行,故需要创建基于四DATE 类型的触发器,其触发条件是更新职工职称级别:最后添加表连接条件。完整的触发器实现的方案如下:
CREATE TRIGGER Salary_TRG AFTER UPDATE OF Title ON EMP
REFERENCING new row AS nrow
FOR EACH ROW
BEGIN
UPDATE WORKS
SET Salary = Salary value(nrow.Eno)
WHERE WORKS. Eno= nrow. Eno;
END
【问题 3】
SQL 查询通过 SELECT 语句实现。
(1)根据问题要求,可通过子查询实现"查询员工最多的公司编号和公司名称"的查询:对COUNT 函数计算的结果应通过 HAVING 条件语句进行约束:通过 Cno 和 Cname的组合来进行分组查询。完整的 SQL 语句如下:
SELECT COMPANY.Cno , Cname FROM COMPANY ,WORKS
WHERE COMPANY.Cno = WORKS. Cno
GROUP BY COMPANY.Cno ,Cname
HAVING COUNT(*) >= ALL (SELECT COUNT(*)
FROM WORKS
GROUP BY Cno
);
(2)根据问题要求,需要使用嵌套查询。先将 WORKS 和 COMPANY 表进行连接, 查找出所有在"中国银行北京分行"工作的员工:然后在雇员表中使用 "NOTIN" 或者 "<>ANY" 查询不在前述结果里面的员工即可。完整的 SQL 语句如下:
SELECT Eno ,Ename FROM EMP
WHERE Eno NOT IN 或 <>ANY (
SELECT Eno
FROM WORKS ,COMPANY
WHERE WORKS.Cno = COMPANY. Cno
AND Cname =‘中国银行北京分行'
);