Oracle触发器
来源: 作者: 时间:2011/5/18 10:41:04

  --创建触发器(行级触发器)

  create or replace trigger tri_update_emp_bak

  after update

  on emp_bak

  for each row  --每更新一行 就触发一次

  begin

  --Oracle 里面 对触发器 也提供了特殊的对象 :NEW :OLD 来访问 更新前后的数据

  dbms_output.put_line('更新后' || :NEW.sal);

  dbms_output.put_line('更新前' || :OLD.sal);

  if updating then

  end if;

  if inserting

  end;

  --创建触发器(行级触发器)(前置)

  create or replace trigger tri3_update_emp_bak

  before update

  on emp_bak

  for each row  --每更新一行 就触发一次

  begin

  --oracle 里面 对触发器 也提供了特殊的对象 :NEW :OLD 来访问 更新前后的数据

  dbms_output.put_line('更新后' || :NEW.sal);

  dbms_output.put_line('更新前' || :OLD.sal);

  end;

  select * from emp_bak

  update emp_bak set sal = 1000 where empno in (7788)

  --创建触发器(表级触发器)

  --//表级别触发器里面 不允许使用 :NEW :OLD 变量

  create or replace trigger tri2_update_emp_bak

  after update

  on emp_bak

  begin

  -- dbms_output.put_line('更新后' || :NEW.sal);

  --dbms_output.put_line('更新前' || :OLD.sal);

  end;

  --创建触发器(行级触发器)

  create or replace trigger tri4_update_emp_bak

  after update of sal

  on emp_bak

  for each row  --每更新一行 就触发一次

  begin

  --oracle 里面 对触发器 也提供了特殊的对象 :NEW :OLD 来访问 更新前后的数据

  dbms_output.put_line('更新后' || :NEW.sal);

  dbms_output.put_line('更新前' || :OLD.sal);

  end;

  create table userinfo

  (

  userid number(4) PRimary key,

  username varchar2(20)

  )

  create table addrinfo

  (

  addrid number(4) primary key,

  addname varchar2(20),

  userid number(4) references userinfo(userid)

  )

  insert into userinfo values (1,'李四')

  insert into addrinfo values (1,'湖北武汉',1)

  select * from addrinfo

  delete from userinfo where userid =1

  --级联删除

  create or replace trigger tri_userinfo_delete

  before  delete

  on userinfo

  for each row

  begin

  delete from   addrinfo  where userid = :OLD.userid;

  -- insert into

  end;

  create table dept_bak as select * from dept

  create or replace view  myview

  as

  select a.empno,a.ename,a.sal,b.dname

  from emp a inner join dept b

  on a.deptno = b.deptno

  select * from myview

免责声明:本文仅代表作者个人观点,与总裁世界无关。其原创性以及文中陈述内容的真实性、完整性、及时性本站不作任何保证或承诺,总裁世界对所有观点均保持中立态度,请读者仅作参考,并请自行核实相关内容。
网站首页 - 关于我们 - 版权声明 - 广告服务 - 网站地图 - 会员专区 - 客户服务 - 疑难解答 - 联系我们
总裁世界 版权所有Copyright © 2004 - 2017 www.ceoedu.com/www.ceoedu.com
总机电话:0755-88844436   业务联系:0755-83692700   中国·深圳 粤ICP备14047004号
客服咨询
24小时客服在线
马上咨询