1)1)定义S, C表,定义实体完整性约束,定义学生的年龄在19到22岁之间,课程名唯一的约束 2)在C表中增加cpno字段,cpno字段为先修课号,定义cpno为外码,参照C表的cno,并定义当删除被参照表中相关记录时,要求违约处理方式为置空,当发生修改操作时,违约处理方式为级联。 3)定义SC表的实体及参照完整性约束,要求当其被参照表发生删除操作时,S表违约处理的方式为级联,当其被参照表发生修改操作时,违约处理的方式为拒绝。 4)触发器 ☆建立一DML触发器,每当学生的成绩发生更新时,将更新的学号,成绩存入g-log表内 ☆建立一个INSTEAD OF触发器,每当删除课程表中记录时,先检查此课程是否已被选修,如选修则不允许删除,且给出提示信息“此课程已有学生已选修,无法删除”
时间: 2023-12-08 10:04:03 浏览: 83
感谢您的问题,根据您的要求,我了解到您需要定义一个数据库的结构,并且需要增加实体完整性约束、参照完整性约束以及触发器。下面是我的回答:
1. 创建S表和C表,并定义实体完整性约束:
CREATE TABLE S (
Sno CHAR(8) PRIMARY KEY,
Sname VARCHAR(20) NOT NULL,
Ssex VARCHAR(2),
Sage INT CHECK (Sage BETWEEN 19 AND 22),
Sdept VARCHAR(20)
);
CREATE TABLE C (
Cno CHAR(4) PRIMARY KEY,
Cname VARCHAR(20) NOT NULL UNIQUE,
Cpno CHAR(4),
FOREIGN KEY (Cpno) REFERENCES C(Cno) ON DELETE SET NULL ON UPDATE CASCADE
);
2. 在C表中增加cpno字段,并定义参照完整性约束:
ALTER TABLE C ADD cpno CHAR(4);
ALTER TABLE C ADD FOREIGN KEY (cpno) REFERENCES C(Cno) ON DELETE SET NULL ON UPDATE CASCADE;
3. 创建SC表,并定义参照完整性约束:
CREATE TABLE SC (
Sno CHAR(8),
Cno CHAR(4),
Grade INT,
PRIMARY KEY (Sno, Cno),
FOREIGN KEY (Sno) REFERENCES S(Sno) ON DELETE CASCADE ON UPDATE CASCADE,
FOREIGN KEY (Cno) REFERENCES C(Cno) ON DELETE CASCADE ON UPDATE CASCADE
);
4. 创建触发器:
CREATE TABLE g_log (
Sno CHAR(8),
Cno CHAR(4),
Grade INT
);
CREATE TRIGGER update_grade
AFTER UPDATE ON SC
FOR EACH ROW
BEGIN
INSERT INTO g_log(Sno, Cno, Grade) VALUES (NEW.Sno, NEW.Cno, NEW.Grade);
END;
CREATE TRIGGER instead_of_delete
INSTEAD OF DELETE ON C
FOR EACH ROW
BEGIN
DECLARE selected INT;
SELECT COUNT(*) INTO selected FROM SC WHERE Cno = OLD.Cno;
IF selected > 0 THEN
SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = '此课程已有学生已选修,无法删除';
ELSE
DELETE FROM C WHERE Cno = OLD.Cno;
END IF;
END;
以上就是根据您的要求所创建的数据库结构,希望可以帮助到您。
阅读全文