zoukankan      html  css  js  c++  java
  • Oracle中的instead of触发器

    Instead of : 用Trigger的内容替换 事件本身的动作,该触发器用在视图上,举例:

    一:创建一个update替代触发器

    (1)创建一个视图

    1 create or replace view my_view
    2 as
    3 select id,name from my_table;

    查询到视图中的数据如下图:

    (2)创建一个update替代触发器,当update视图数据时触发,打印输出下列红色字体语句,来代替更新视图数据

    1 create or replace trigger u_trigger
    2 instead of
    3 update on my_view
    4 for each row
    5    
    6 begin
    7   dbms_output.put_line('执行update替代触发器!');
    8 end;

    (3)执行SQL语句,并查看结果,红色框是触发器触发时输出的结果

    二:创建一个delete替代触发器

     (1)创建一个视图

    1 create or replace view my_view
    2 as
    3 select id,name from my_table;

    查询到视图中的数据如下图:

    (2)创建一个delete替代触发器,当delete视图数据时触发,打印输出下列红色字体语句,来代替删除视图数据

    1 create or replace trigger d_trigger
    2 instead of
    3 delete on my_view
    4 for each row
    5   
    6 begin
    7   dbms_output.put_line('执行delete替代触发器!');
    8 end;

    (3)执行SQL语句,并查看结果,红色框是触发器触发时输出的结果

  • 相关阅读:
    java面试题
    linux下的文件目录结构
    Linux的基础命令
    Linux系统的介绍
    逻辑思维题
    37-字符的全排列
    36-螺旋矩阵
    35-面试:如何找出字符串的字典序全排列的第N种
    34-数细线
    33-求极差
  • 原文地址:https://www.cnblogs.com/AI-xiaocai/p/11203249.html
Copyright © 2011-2022 走看看