pl/sql之trigger

触发器是当特定事件出现时自动执行的存储过程,特定事件可以是执行更新的DML语句和DDL语句,触发器不能被显式调用;

触发器的功能:

         自动生成数据;
         自定义复杂的安全权限;
         提供审计和日志记录;
         启用复杂的业务逻辑;

创建trigger语法:

CREATE [OR REPLACE] TRIGGER trigger_name
AFTER | BEFORE | INSTEAD OF
[INSERT] [[OR] UPDATE [OF column_list]] [[OR] DELETE]
ON table_or_view_name
[REFERENCING {OLD [AS] old / NEW [AS] new}]
[FOR EACH ROW]
[WHEN (condition)]
pl/sql_block;

触发器由三部分组成:
1,触发器语句(事件):
     定义激活触发器的 DML 事件和 DDL 事件;
2,触发器限制:
     执行触发器的条件,该条件必须为真才能激活触发器;
3,触发器操作(主体):
     包含一些 SQL 语句和代码,它们在发出了触发器语句且触发限制的值为真时运行;

例:

CREATE OR REPLACE TRIGGER aiu_itemfile
	AFTER INSERT ON itemfile
	FOR EACH ROW
BEGIN
	IF (:NEW.qty_hand = 0) THEN
		DBMS_OUTPUT.PUT_LINE('警告:已插入记录,但数量为零');
	ELSE
		DBMS_OUTPUT.PUT_LINE(‘已插入记录');
	END IF;
END;
/

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值