实 验 报 告 | ||
题目:触发器实验 | 姓名: | |
实验名称 | 触发器实验 | |
实验内容 | 1.创建一个触发器,要求:当对表sc的grade进行修改时,若分数增加了10%,则将此次操作记录到另一个表中sc_u(sno,cno,oldgrade,newgrade)2.创建触发器,作用是:当在学生表S中删除某一个学生时,在学生选课表SC中的选课记录也全部被删除。 3.创建触发器,该触发器能够保证在学生选课表SC表中添加新的记录时,新学生的学号SNO必须已经存在于学生基本信息表S中。 | |
实验内容 | ||
CREATE TRIGGER tr_sc_grade_change ON sc AFTER UPDATE AS BEGIN IF UPDATE(grade) BEGIN INSERT INTO sc_u(sno, cno, oldgrade, newgrade) SELECT i.sno, i.cno, d.grade, i.grade FROM inserted i INNER JOIN deleted d ON i.sno = d.sno AND i.cno = d.cno WHERE i.grade > d.grade * 1.1; -- 判断分数是否增加了 10% END END
CREATE TRIGGER tr_delete_student ON Student AFTER DELETE AS BEGIN DELETE FROM SC WHERE sno IN (SELECT sno FROM deleted) END 3.创建触发器,该触发器能够保证在学生选课表SC表中添加新的记录时,新学生的学号SNO必须已经存在于学生基本信息表S中。 CREATE TRIGGER tr_insert_sc ON SC INSTEAD OF INSERT AS BEGIN IF EXISTS(SELECT 1 FROM inserted i LEFT JOIN S s ON i.sno = s.sno WHERE s.sno IS NULL) BEGIN RAISERROR('The student does not exist in table S.', 16, 1); ROLLBACK TRANSACTION; RETURN; END INSERT INTO SC SELECT * FROM inserted; END | ||
实验结果 | ||
![]() ![]() ![]() | ||
实验结论 | ||
本次触发器实验旨在学习数据库触发器的创建和使用。通过实验,我完成了以下几个任务: 创建触发器:我成功创建了三个触发器,分别满足不同的要求。第一个触发器在表sc的grade字段被修改时,检测是否增加了10%,如果是,则将此次操作记录到另一个表sc_u中。第二个触发器在学生表S中删除某一学生时,自动删除学生选课表SC中相关的选课记录。第三个触发器在学生选课表SC中插入新的记录时,检测新学生的学号SNO是否已存在于学生基本信息表S中,保证数据的完整性。 实验结论: 通过本次实验,我深入理解了触发器在数据库中的作用和应用场景。触发器是数据库中的一种特殊对象,它能够在特定的事件发生时自动触发一系列操作。触发器可以用于实现数据的完整性约束、业务逻辑的自动化处理等。 在实验过程中,我学会了创建触发器的语法和使用方法,并成功实现了不同类型的触发器。触发器能够提高数据库的数据一致性和完整性,减少了手动操作的错误和遗漏。通过触发器,可以实现一些复杂的业务逻辑,简化应用程序的开发和维护工作。 总而言之,触发器是数据库中非常有用的功能,对于确保数据的一致性、完整性和安全性具有重要作用。我将继续学习和探索数据库触发器的更多应用场景,并将其运用到实际的数据库设计和开发中,提升数据库管理和应用开发的水平。 |
数据库系统概论之触发器实验
于 2023-12-22 23:38:51 首次发布