oracle触发器及异常处理 简单例子

Posted 肥宅兜

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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);  
 

 

以上是关于oracle触发器及异常处理 简单例子的主要内容,如果未能解决你的问题,请参考以下文章

Oracle的基本语法,存储函数及触发器

ORACLE异常处理及函数

ORA-06510: PL/SQL: 未处理的用户定义异常 [Oracle]

Oracle 异常未在触发器中捕获

Oracle的PL_SQL的异常处理

Oracle-4 - :超级适合初学者的入门级笔记:plsql,基本语法,记录类型,循环,游标,异常处理,存储过程,存储函数,触发器