a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 數據庫 > Oracle > 正文

Oracle觸發器

2024-08-29 13:54:02
字體:
來源:轉載
供稿:網友
--創建觸發器(行級觸發器)   
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   
  
update  myview set sal = 1000,dname='aaaaa' where empno = 7499  
  
  
--替代觸發器  用在視圖上面 只能是行級的   
--替代觸發器 特點是 真正的操作已經 變成了一個動作而已 功能由觸發器來完成   
create or replace trigger tri_myview   
instead of update    
on myview    
begin  
  
   dbms_output.put_line('刪除操作執行了。。。');   
   update emp set sal = :NEW.sal where empno = :OLD.empno;   
      
   update dept set dname = :NEW.dname where dname = :OLD.dname;   
   --delete from emp where empno = :OLD.empno;   
  
end;   
  
  
  
select * from emp;   
select * from dept;   
  
  
update emp_bak set ename ='aaaa',sal = 10000 where empno in (7788)   
  
  
--系統包   
-- 產生隨機數   
**** **** **** ****   
--dbms_random.value 0-1 之間的隨機小數   
--dbms_random.random  隨機整數   
select dbms_random.value from dual;   
  
  
  
create or replace procedure proc_cardno(mycardno out varchar2)   
as  
   tempcard varchar2(50);   
   cardno varchar2(19);   
begin  
   tempcard:= dbms_random.value;   
       
   cardno:=substr(tempcard,2,4)||' '||substr(tempcard,6,4)||' '||substr(tempcard,10,4)||' '||substr(tempcard,14,4);   
        
   mycardno:=cardno;   
      
--   dbms_output.put_line(tempcard);   
  -- dbms_output.put_line(cardno);   
end;   
  
  
  
  
  
  
--使用UTL_FILE包讀寫文件   
create directory MY_DIR as 'd:/temp';   
create directory MY_DIR2 as 'd:/temp2';   
  
declare   
  --定義文件對象    
   myfile utl_file.file_type;   
  --定義變量 用來存儲每讀出一行的數據   
   linestr varchar2(200);   
begin  
   --打開文件       
     myfile:= utl_file.fopen('MY_DIR','oracle.log','r');   
      
   --進行讀取(循環)   
   loop   
           utl_file.get_line(myfile,linestr);   
           dbms_output.put_line(linestr);   
   end loop;   
         
     exception   
       when others  then    
           utl_file.fclose(myfile);   
          dbms_output.put_line('讀取完畢!');   
              
end;   
  
  
  
  
  
  
declare   
  --定義文件對象    
   myfile utl_file.file_type;   
  --定義變量 用來存儲每讀出一行的數據   
   linestr varchar2(200);   
begin  
   --打開文件       
     myfile:= utl_file.fopen('MY_DIR','oracle.log','a');   
      
   --追加數據   
     
           --utl_file.get_line(myfile,linestr);   
           utl_file.put_line(myfile,'你好,這是新的數據',true);   
         
            utl_file.fclose(myfile);   
      exception   
       when others  then    
           utl_file.fclose(myfile);   
          dbms_output.put_line('讀取完畢!');   
              
end;   
  
  
--拷貝   
  
  
  
declare   
  --定義文件對象    
   sourcefile utl_file.file_type;   
   targetfile utl_file.file_type;   
  --定義變量 用來存儲每讀出一行的數據   
   linestr varchar2(200);   
begin  
   --打開文件       
     sourcefile:= utl_file.fopen('MY_DIR','oracle.log','r');   
     targetfile:= utl_file.fopen('MY_DIR2','copy.txt','a');   
        
   --進行讀取(循環) 并且寫入到新的文件里面   
   loop   
            utl_file.get_line(sourcefile,linestr);   
            utl_file.put_line(targetfile,linestr,true);   
          -- dbms_output.put_line(linestr);   
   end loop;   
         
     exception   
       when others  then    
           utl_file.fclose(sourcefile);   
            utl_file.fclose(targetfile);   
          dbms_output.put_line('拷貝完畢!');   
              
end;  


本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/hzz1988/archive/2009/12/30/5107869.aspx
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美第8页| 四虎精品成人免费网站 | 国产精品视频 | 天堂一区二区三区 | 亚洲精品一区二区三区在线 | 欧美a区 | 国产乱淫av片 | 久久99精品久久久久久水蜜桃 | 亚洲最新中文字幕 | 亚洲毛片在线观看 | 91成人一区 | 国产精品久久久久久久久久久久久久 | 亚洲精品久久久久avwww潮水 | 欧美一区二区三 | 欧美日韩在线看 | 精品视频在线免费观看 | 婷婷免费在线观看 | 中文字幕在线免费 | 日韩在线免费 | 欧美亚洲高清 | 日韩成人在线播放 | 欧美成人一区二区 | 免费xxxx大片国产在线 | 亚洲一二三区在线观看 | 91夜夜夜| www.日韩 | 中国特级黄色片 | eeuss影院一区二区三区 | 爱爱视频免费播放 | 欧洲成人在线观看 | 久久久久久久久久久久久国产精品 | 久久精品国产精品青草 | 91精品国产色综合久久不卡98 | 欧美日韩一区二区在线观看 | 黄色网av| 国产一区二区三区久久久久久久久 | 天天干天操 | av在线一区二区三区 | 欧洲毛片 | 色爱av| 国内成人精品2018免费看 |