实验四:触发器实验

实验四:触发器实验
4.1 实验目的
掌握数据库触发器的设计和使用方法。

4.2 实验内容和要求
定义 BEFORE 触发器和 AFTER 触发器。能够理解不同类型触发器的作用和执行原理,验证触发器的有效性。

4.3 实验重点和难点
实验重点:触发器的定义。
实验难点:利用触发器实现较为复杂的用户自定义完整性。

4.4 实验内容记录
在这里插入图片描述
在这里插入图片描述

4.4.1 AFTER 触发器
4.4.1.1 insert
在这里插入图片描述

在订单表上创建触发器,当有订单时,根据订单的产品编号和数量自动减少产品的数量。触发器中NEW代表一个表,存放插入的订单记录。
验证:
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

4.4.1.2 update
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


在这里插入图片描述

4.4.1.3 delete
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述


在这里插入图片描述
在这里插入图片描述


在这里插入图片描述

4.4.2 BEFORE 触发器
4.4.2.1 insert
在订单表上创建新的触发器,当订单定的某产品产品数量大于产品库存,禁止下订单,也就是禁止在订单表中插入记录。
在这里插入图片描述

当前product中产品的数目小于订单需要的数目时执行SELECT XXXX INTO mesg语句,因为XXXX列并不存在,因此无法执行成功,这样可以保证数据完整性。
验证:
在这里插入图片描述

4.4.2.2 update
触发器设置成before update,在更改前检查价格增长幅度是否超过20%,如果超过就产生错误,取消操作。
更新操作分为两步,第一步是删除原来的记录,第二步是插入新记录。原来的记录在old表中,新记录在new表中。触发器中new.price存放的是新价格,old.price是原来的价格。
在这里插入图片描述
在这里插入图片描述

涨幅超过20%
在这里插入图片描述

4.4.2.3 delete
在这里插入图片描述

4.4.3 删除触发器

在这里插入图片描述

4.5 思考题
试设计一个AFTER触发器,当Lineitem表中的quantity变化时,自动计算Lineitem表中的extendedprice值,同时也要修改PartSupp中的availqty值(提示: extendedprice = quantity *Part.retailprice)。

CREATE TRIGGER emp_update
AFTER UPDATE ON Lineitem
FOR EACH ROW
BEGIN
  IF(new.quantity!=old.quantity)
  THEN
    UPDATE Lineitem set Lineitem = quantity *Part.retailprice;
		UPDATE PartSupp set availqty=new.availqty;
  END IF;
END;

4.6实验总结
本次实验通过实践学习到了MYSQL的触发器的使用,了解到触发器的一些功能用处以及缺点。学习了如何定义 BEFORE 触发器和 AFTER 触发器,能够理解不同类型触发器的作用和执行原理,验证触发器的有效性。在INSERT型触发器中,NEW用来表示将要(BEFORE)或已经(AFTER)插入的新数据;在UPDATE型触发器中,OLD用来表示将要或已经被修改的原数据,NEW用来表示将要或已经修改为的新数据;在DELETE型触发器中,OLD用来表示将要或已经被删除的原数据;另外,OLD是只读的,而NEW则可以在触发器中使用SET赋值,不会再次触发触发器,造成循环调用。

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值