欢迎投稿

今日深度:

oracle触发器中增删改查本表

oracle触发器中增删改查本表


oracle触发器中增删改查本表
 
(1)只有before insert触发器中才可以查询或更新本表
create or replace trigger tri_test_ins 
before insert
on test
for each row
declare
  v_cnt integer;
begin
 select count(*) into v_cnt from test;
 dbms_output.put_line('test count:'||to_char(v_cnt));
 update test set a9='99';
end;

 

执行insert后,只有当前插入的记录值不是99,其它的记录都被更新成了99。
(2)before/after update、before/after delete、after insert5种情况都不可以查询或更新本表。
(3)使用自治事务可以实现任意触发器查本表。但不能实现在自治事务中更新本表。
  查询本表的情况是最常见的。
create or replace trigger tri_test_ins
after update
on test
for each row
declare
  v_cnt integer;
  PRAGMA AUTONOMOUS_TRANSACTION;
begin
 begin
        select count(*) into v_cnt from test;
        dbms_output.put_line('test count:'||to_char(v_cnt));
 end;
end;

 

(4)使用自治事务可以实现新增或删除本表的记录。这种情况一般不会用到。

www.htsjk.Com true http://www.htsjk.com/oracle/21460.html NewsArticle oracle触发器中增删改查本表 oracle触发器中增删改查本表 (1)只有before insert触发器中才可以查询或更新本表 create or replace trigger tri_test_ins before inserton testfor each rowdeclare v_cnt integer;begin se...
相关文章
    暂无相关文章
评论暂时关闭