数据库系统概论之触发器实验

实 验 报 告

题目:触发器实验

姓名:

实验名称

触发器实验

实验内容

1.创建一个触发器,要求:当对表sc的grade进行修改时,若分数增加了10%,则将此次操作记录到另一个表中sc_u(sno,cno,oldgrade,newgrade)

2.创建触发器,作用是:当在学生表S中删除某一个学生时,在学生选课表SC中的选课记录也全部被删除。

3.创建触发器,该触发器能够保证在学生选课表SC表中添加新的记录时,新学生的学号SNO必须已经存在于学生基本信息表S中。

实验内容

  1. 创建一个触发器,要求:当对表sc的grade进行修改时,若分数增加了10%,则将此次操作记录到另一个表中sc_u(sno,cno,oldgrade,newgrade)

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

  1. 创建触发器,作用是:当在学生表S中删除某一个学生时,在学生选课表SC中的选课记录也全部被删除。

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中,保证数据的完整性。

实验结论:

通过本次实验,我深入理解了触发器在数据库中的作用和应用场景。触发器是数据库中的一种特殊对象,它能够在特定的事件发生时自动触发一系列操作。触发器可以用于实现数据的完整性约束、业务逻辑的自动化处理等。

在实验过程中,我学会了创建触发器的语法和使用方法,并成功实现了不同类型的触发器。触发器能够提高数据库的数据一致性和完整性,减少了手动操作的错误和遗漏。通过触发器,可以实现一些复杂的业务逻辑,简化应用程序的开发和维护工作。

总而言之,触发器是数据库中非常有用的功能,对于确保数据的一致性、完整性和安全性具有重要作用。我将继续学习和探索数据库触发器的更多应用场景,并将其运用到实际的数据库设计和开发中,提升数据库管理和应用开发的水平。

  • 24
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LucianaiB

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值