oracle 触发器执行ddl,oracle触发器——ddl触发器

什么是ddl(data definition language),说白了就是我们经常用的create、alter和drop这些数据定义语句。

n  创建ddl触发器

请编写一个触发器,可以记录某个用户进行的ddl操作

基本语法:

create or replace trigger触发器名

after ddl on方案名.schema   --如:scott.schema

begin

//执行语句

end;

①为了记录系统所发生的ddl事件,应该建立一张表(my_ddl_event)用力存相关信息,注意需要使用system用户登录conn system/manager as sysdba

字段名

字段类型

event

varchar2(20)

username

varchar2(20)

time

date

SQL> create table my_ddl_event (event varchar2(20),username varchar2(20),time date);

②创建该触发器tr_ddl

create or replace trigger tri9

after ddl on scott.schema

begin

insert into my_ddl_event values(ora_sysevent,ora_login_user,sysdate);

end;

③测试触发器是否OK

在oracle中,dml语句需要手动提交(如果没有手动提交,当你退出控制台的时候,oracle会自动提交),ddl语句是自动提交的。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值