Oracle触发器(trigger):view,schema,database
视图trigger, instead of
我们知道如果一个view只是由一个table构成,那在view上做啥操作没太多限制.如果view是由多个table组成那在view上做啥unpdate,insert,delete都会出错.但有时又确实要做这些操作该咋办呢.这就需要用到trigger,然后通过instead of关键字来指定一些替代操作.
举个简单例子,如果有view, my_view创建trigger如下
create or replace trigger my_view_trigger
instead of insert or update
on my_view
declare
insert into tmp(eno) values(:new.eno);
end;
当执行sql : insert into my_view(eno, name) values(88,'test');时触发trigger.
不过view的instead of类型的trigger相对其他类型trigger有个特别的地方.从名字也可以看出来,可以替换掉了触发它的sql的操作.也就是insert into my_view(eno, name) values(88,'test');这个sql本身的操作不会起作用了.只有trigger里面的pl/sql语句块才真正执行.
注意事项:
1.instead of 类型触发器只能针对view创建,并且该view上不能有些check option(比如with check read only之类的),这以所这样是防止不同的功能之间的冲突.假如是一个read only类型的view,那自然不能整出个trigger又可以做些DML操作了.
2.不能指定before或after选项,因为触发trigger的sql实际上并不会执行,所以before或after就没有啥意义了.
Database , Schema级别trigger
针对表和视图的Triggers可能开发人员用的多.针对database,schema的Trigger一般是DBA用的多点.
比如创建trigger每当schema上有DDL操作时触发(针对表或视图的trigger只能针对DML操作,不能针对DDL操作).
举个简单的例子
CREATE OR REPLACE TRIGGER ddl_trigger
AFTER DDL ON SCHEMA
BEGIN
insert into tblog values(systimestamp,ora_sysevent, ora_login_user,
ora_dict_obj_type, ora_dict_obj_name);
END;
其中ora_login_user是登陆名,ora_dict_obj_type对象类型(比如表或视图),ora_dict_obj_name是对象名字,比如表名或视图名.你可能看到这些变量貌似没在哪里定义.实际上是oracle定义好的,你只要拿来用就行.
假如随便用哪个用户执行如下sql: create table tmp_tb(eno int); 就会触发trigger.
不过貌似上面不能直接指定是具体的哪个schema,只能针对所有schema了啊.
假如用户每次登陆时要做些记录.那可以创建如下trigger
CREATE OR REPLACE TRIGGER logon_trigger
AFTER LOGON ON DATABASE
BEGIN
INSERT INTO tblog VALUES (ora_login_user, ora_client_ip_address, systimestamp);
END ;
这里的logon on database不是说数据库启动,而是每次连接一个session的时候.
最新文章
- pkcs1与pkcs8格式RSA私钥互相转换
- 【记录】ASP.NET MVC JsonResult JsonRequestBehavior AllowGet
- TCP与UDP的区别
- NOIP模拟赛 寻找
- ES6新特性:增加新类型:Symbol
- IC/RFID/NFC 关系与区别
- jQuery 通用表单方法
- 忘记root密码修改方法
- Qt Creator插件工作流程代码走读
- PHP实现JS点击点击定位
- 服务器重新启动,ftp重新连接问题
- touch-action属性引起的探索
- oracle中字符串与表数据拼接的用法--“||”
- jsp-提交表单时,select的值无法传递
- 软件工程第二次作业(JUnit的使用)
- 什么是springMvc的参数绑定?
- centos7 搭建svn服务
- Linux 不杀进程的情况下,如何释放磁盘资源
- luoguP3830 [SHOI2012]随机树 期望概率 + 动态规划 + 结论
- pom配置之:snapshot快照库和release发布库
热门文章
- 使用Notepad++开发python配置笔记
- Python环境变量配置问题
- 《windows程序设计》学习_4.1:计时器(可用于扫雷)
- C++中顶层const和底层const
- 一个cocoapods问题的解决,希望能帮助到遇到相似情况的人
- css滤镜(转载)
- sublime text 3解放鼠标的快捷键总结
- 关于使用由CA机构(EJBCA)颁发的证书实现SLLSocket双向认证服务端报null cert chain的解决方案
- GWT RPC机制
- spring mvc框架 遇到的问题