oracle觸發器及異常處理 簡單例子


Java代碼   收藏代碼
  1. create sequence person_seq        
  2. start with 1                  
  3. increment by 1               
  4. order                     --按順序  
  5. nocycle                 --不循環不重復  
  6. ;  
  7.   
  8.   
  9.   
  10. insert into person values(person_seq.nextval,null,'iteye);  
  11. delete from person;  
  12. update person set user_name ='zwllxs6' where id = 3;  
  13.   
  14. ---觸發器  
  15. create or replace trigger person_tr before insert or update or delete on person      
  16. for each row     
  17. Declare   
  18.    can_not_update_exception  EXCEPTION;   
  19.   
  20. begin  
  21.   
  22.     dbms_output.put_line('testest');  
  23.     if inserting then     
  24.        dbms_output.put_line('inserting');  
  25.     end if;  
  26.     if updating then     
  27.        dbms_output.put_line('updating');  
  28.        dbms_output.put_line('old: '||:old.user_name);  
  29.        dbms_output.put_line('new: '||:new.user_name);  
  30.        if(:old.user_name<>:new.user_name) then  
  31.           dbms_output.put_line('不一樣,不能更新');      
  32.          Raise_application_error(-20000,'不一樣,不能更新');                        
  33.        end if;  
  34.          
  35.     end if;  
  36.     if deleting then     
  37.        dbms_output.put_line('deleting');  
  38.     end if;  
  39. end;  


Java代碼   收藏代碼
  1. Class.forName("oracle.jdbc.driver.OracleDriver");   
  2.             Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:orcl", "scott", "******");   
  3.               
  4.             // 創建狀態     
  5.             Statement stmt = conn.createStatement();     
  6.             // 執行SQL語句,返回結果集     
  7.             ResultSet rs = stmt.executeQuery("SELECT * FROM person");     
  8.             while (rs.next()) {     
  9.                 int id = rs.getInt("id");    
  10.                 String userName = rs.getString("user_name");    
  11.                 System.out.println("id: "+id);  
  12.                 System.out.println("userName: "+userName);  
  13.             }  
  14.               
  15.             int num=stmt.executeUpdate("update person set user_name ='zwllxs5' where id = 3");  
  16.             System.out.println("num: "+num);  
 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM