列表

详情


阅读下列说明,回答问题1至问题3,将解答填入答题纸的对应栏内。
【说明】   
某大型集团公司的数据库的部分关系模式如下:
员工表:EMP(Eno,Ename,Age,Sex,Title),各属性分别表示员工工号、姓名、年龄、性别和职称级别,其中性别取值为“男”“女”;
公司表:COMPANY(Cno,Cname,City),各属性分别表示公司编号、名称和所在城市;
工作表:WORKS(Eno,Cno,Salary),各属性分别表示职工工号、工作的公司编号和工资。
有关关系模式的属性及相关说明如下:
(1)允许一个员工在多家公司工作,使用身份证号作为工号值。
(2)工资不能低于1500元。
根据以上描述,回答下列问题:
【问题1】(4分)
请将下面创建工作关系的SQL语句的空缺部分补充完整,要求指定关系的主码、外码,以及工资不能低于1500元的约束。
CREATE TABLE WORKS(
         Eno CHAR(10)    (a)  ,
        Cno CHAR(4)    (b)  ,
        Salary int    (c)  ,
        PRIMARY KEY    (d)  ,
 );   
【问题2】(6分)
(1)创建女员工信息的视图FemaleEMP,属性有Eno、Ename、Cno、Cname和Salary,请将下面SQL语句的空缺部分补充完整。
CREATE    (e)  
        AS
        SELECT EMP.Eno,Ename,COMPANY.Cno,Cname,Salary
        FROM   EMP, COMPANY, WORKS
        WHERE    (f)  ;
(2)员工的工资由职称级别的修改自动调整,需要用触发器来实现员工工资的自动维护,函数float Salary_value(char(10) Eno)依据员工号计算员工新的工资。请将下面SQL语句的空缺部分补充完整。
CREATE   (g)   Salary_TRG AFTER   (h)   ON EMP
    REFERENCING new row AS nrow
    FOR EACH ROW
    BEGIN
        UPDATE WORKS
        SET   (i)  
        WHERE   (j)  ;
    END
【问题3】(5分)
请将下面SQL语句的空缺部分补充完整。
(1)查询员工最多的公司编号和公司名称。
    SELECT COMPANY.Cno,Cname
    FROM COMPANY,WORKS
    WHERE COMPANY.Cno= WORKS.Cno
    GROUP BY   (k)  
        HAVING   (l)   ( SELECT  COUNT(*)
                                   FROM  WORKS
                                   GROUP BY Cno
                                    );
(2)查询所有不在“中国银行北京分行”工作的员工工号和姓名。
    SELECT Eno,Ename
    FROM EMP
    WHERE Eno   (m)   (
        SELECT  Eno
        FROM   (n)  
        WHERE  (o)  
                      AND  Cname=‘中国银行北京分行’
    );

参考答案:

【问题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   =‘中国银行北京分行'
);

上一题