【Oracle】Oracle创建触发器

本文介绍了如何在Oracle 11g中创建一个行级触发器,该触发器在删除user_info表的数据之前记录删除信息到tr_log_user_info_del日志表中。通过示例展示了具体的PL/SQL代码,包括创建日志表、定义触发器以及执行删除操作后的日志查询。这有助于数据监督和审计。
摘要由CSDN通过智能技术生成

plsql版本:13.0.2
Oracle版本:Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production

创建触发器

(以删除操作触发器为例)

-- 先创建一个日志表用于存储删除操作的记录
CREATE TABLE tr_log_user_info_del AS SELECT * FROM user_info WHERE 1=2; 
alter table tr_log_user_info_del add (trigger_date date);

-- 创建行级的删除操作触发器
CREATE OR REPLACE TRIGGER tr_del_user_info 
   BEFORE DELETE --指定触发时机为删除操作前触发
   ON shop.user_info 
   FOR EACH ROW   --说明创建的是行级触发器 
BEGIN
   --将删除前数据插入到日志记录表,以供监督使用。
   INSERT INTO tr_log_user_info_del(userno , user_name, user_age , trigger_date)
       VALUES( :old.userno, :old.user_name, :old.user_age , sysdate);
END;


--select * from tr_log_user_info_del;
--DELETE user_info WHERE userno=3;

--DROP TABLE tr_log_user_info_del;
--DROP TRIGGER tr_del_user_info;

验证

执行删除操作:

DELETE user_info WHERE userno=4;

执行时间为 10:01:11:
在这里插入图片描述

查询trigger日志表:

在这里插入图片描述

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值