视图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的时候.

最新文章

  1. pkcs1与pkcs8格式RSA私钥互相转换
  2. 【记录】ASP.NET MVC JsonResult JsonRequestBehavior AllowGet
  3. TCP与UDP的区别
  4. NOIP模拟赛 寻找
  5. ES6新特性:增加新类型:Symbol
  6. IC/RFID/NFC 关系与区别
  7. jQuery 通用表单方法
  8. 忘记root密码修改方法
  9. Qt Creator插件工作流程代码走读
  10. PHP实现JS点击点击定位
  11. 服务器重新启动,ftp重新连接问题
  12. touch-action属性引起的探索
  13. oracle中字符串与表数据拼接的用法--“||”
  14. jsp-提交表单时,select的值无法传递
  15. 软件工程第二次作业(JUnit的使用)
  16. 什么是springMvc的参数绑定?
  17. centos7 搭建svn服务
  18. Linux 不杀进程的情况下,如何释放磁盘资源
  19. luoguP3830 [SHOI2012]随机树 期望概率 + 动态规划 + 结论
  20. pom配置之:snapshot快照库和release发布库

热门文章

  1. 使用Notepad++开发python配置笔记
  2. Python环境变量配置问题
  3. 《windows程序设计》学习_4.1:计时器(可用于扫雷)
  4. C++中顶层const和底层const
  5. 一个cocoapods问题的解决,希望能帮助到遇到相似情况的人
  6. css滤镜(转载)
  7. sublime text 3解放鼠标的快捷键总结
  8. 关于使用由CA机构(EJBCA)颁发的证书实现SLLSocket双向认证服务端报null cert chain的解决方案
  9. GWT RPC机制
  10. spring mvc框架 遇到的问题