☆建立一DML触发器,每当学生的成绩发生更新时,检查更新的学号是否满足0-100分之间,如果不满足则不允许更新,如满足则将更新的学号,成绩存入g-log表内
时间: 2024-02-21 13:56:35 浏览: 115
好的,以下是建立DML触发器的SQL语句,它可以实现你的需求:
```sql
CREATE OR REPLACE TRIGGER trg_update_student_score
AFTER UPDATE ON student
FOR EACH ROW
DECLARE
v_score NUMBER;
BEGIN
-- 获取更新后的成绩
v_score := :NEW.score;
-- 判断成绩是否在0-100分之间
IF v_score < 0 OR v_score > 100 THEN
-- 如果不满足条件则不允许更新
RAISE_APPLICATION_ERROR(-20001, '成绩必须在0-100分之间!');
ELSE
-- 如果满足条件则将更新的学号、成绩存入g-log表内
INSERT INTO g_log(student_id, score) VALUES(:NEW.student_id, v_score);
END IF;
END;
```
这个触发器会在每次更新学生表时被触发,然后检查更新的成绩是否在0-100分之间,如果不在则会抛出一个应用程序错误,否则会将更新的学号和成绩存入g-log表内。注意,这个触发器是针对学生表的更新操作,所以需要在学生表上建立。
相关问题
用mysql建立一DML触发器,每当学生的成绩发生更新时,检查更新的学号是否满足0-100分之间,如果不满足则不允许更新,如满足则将更新的学号,成绩存入g_log表内
可以使用以下 SQL 语句在 MySQL 中创建该 DML 触发器:
```
CREATE TRIGGER trig_update_score
BEFORE UPDATE ON student
FOR EACH ROW
BEGIN
DECLARE s_score INT;
SELECT NEW.score INTO s_score;
IF s_score < 0 OR s_score > 100 THEN
SIGNAL SQLSTATE '45000'
SET MESSAGE_TEXT = 'Score out of range!';
ELSE
INSERT INTO g_log (s_id, s_score)
VALUES (NEW.s_id, s_score);
END IF;
END;
```
该触发器会在每次更新学生表(`student`)中的成绩字段(`score`)时触发。首先会将即将更新的成绩值存储到一个变量 `s_score` 中,然后判断该成绩是否在 0 到 100 分之间。如果不在该范围内,则会抛出一个异常,阻止更新操作。如果成绩在范围内,则将该学号和成绩插入到 `g_log` 表中。
1)1)定义S, C表,定义实体完整性约束,定义学生的年龄在19到22岁之间,课程名唯一的约束 2)在C表中增加cpno字段,cpno字段为先修课号,定义cpno为外码,参照C表的cno,并定义当删除被参照表中相关记录时,要求违约处理方式为置空,当发生修改操作时,违约处理方式为级联。 3)定义SC表的实体及参照完整性约束,要求当其被参照表发生删除操作时,S表违约处理的方式为级联,当其被参照表发生修改操作时,违约处理的方式为拒绝。 4)触发器 ☆建立一DML触发器,每当学生的成绩发生更新时,将更新的学号,成绩存入g-log表内 ☆建立一个INSTEAD OF触发器,每当删除课程表中记录时,先检查此课程是否已被选修,如选修则不允许删除,且给出提示信息“此课程已有学生已选修,无法删除”
感谢您的问题,根据您的要求,我了解到您需要定义一个数据库的结构,并且需要增加实体完整性约束、参照完整性约束以及触发器。下面是我的回答:
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;
以上就是根据您的要求所创建的数据库结构,希望可以帮助到您。
阅读全文