Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 964|回复: 0

-存儲过程中的异常 ★

[复制链接]

该用户从未签到

发表于 2011-10-31 12:59:37 | 显示全部楼层 |阅读模式
在Cun储过程中如1何插入.gengxin.删除表中De数据,2求li子?
欢迎来DaoJava学xi者論坛,zhuan載请注明地址:http://www.javaxxz.com.
回复

使用道具 举报

该用户从未签到

发表于 2011-10-31 13:00:31 | 显示全部楼层

Re:-存儲过程中的异常

CREATE OR REPLACE PROCEDURE HR.add_job_history
  ( p_emp_id job_history.employee_id%type
  , p_start_date job_history.start_date%type
  , p_end_date job_history.end_date%type
  , p_job_id job_history.job_id%type
  , p_department_id job_history.department_id%type
  )
IS
BEGIN
  INSERT INTO job_history (employee_id, start_date, end_date,
  job_id, department_id)
  VALUES(p_emp_id, p_start_date, p_end_date, p_job_id, p_department_id);
   
   
exception
  when others then
  dbms_output.put_line('數据插入异常!');
END add_job_history;


在1楼的基础上加上异常处理
回复 支持 反对

使用道具 举报

该用户从未签到

 楼主| 发表于 2011-10-31 13:00:44 | 显示全部楼层

Re:-存儲过程中的异常

借用下一楼的例子
SQL code CREATE OR REPLACE PROCEDURE HR.add_job_history
  (  p_emp_id          job_history.employee_id%type
   , p_start_date      job_history.start_date%type
   , p_end_date        job_history.end_date%type
   , p_job_id          job_history.job_id%type
   , p_department_id   job_history.department_id%type
   )
IS
BEGIN
  INSERT INTO job_history (employee_id, start_date, end_date,
                           job_id, department_id)
    VALUES(p_emp_id, p_start_date, p_end_date, p_job_id, p_department_id);
exception
--when 指定的異常 then
--...
when others then--处理所有异常,一般放在异常处理最后
dbms_output.put_line(sqlcode || sqlerrm);
--sqlcode是oracle錯误号ORA-XXXXX,sqlerrm是錯误信息
END add_job_history;
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-31 13:00:46 | 显示全部楼层

Re:-存儲过程中的异常

用oracle自带的调试工具单步调试即可
方法:打開pl/sql==>找到该存储过程所在的包==>右键包头==>点击“添加调试信息”==>右键該存储过程==>调试==>輸入你的参数(若有的話)==>按F9==>再按Ctl+N
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-31 13:00:54 | 显示全部楼层

Re:-存儲过程中的异常

那样单步调试后就会知道哪句SQL语句有问题了
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-31 13:00:58 | 显示全部楼层

Re:-存儲过程中的异常

SQL code CREATE OR REPLACE PROCEDURE LOAN_BOOK(B_ID IN NUMBER, U_ID IN NUMBER) IS

  OR_ID   NUMBER(6);
  OR_NAME VARCHAR2(1000);
  BK_ID   NUMBER(12);
  BK_NAME VARCHAR2(1000);
  ST_DATE DATE;
  ED_DATE DATE;

  H1 NUMBER(6);
  H2 NUMBER(6);
  H3 NUMBER(6);

  L VARCHAR2(10);
  S VARCHAR2(20);

BEGIN

  SELECT STATUS INTO S FROM BOOK WHERE BOOK_ID = B_ID;

  IF S = '在庫' THEN
  
    SELECT HOLD1, HOLD2, HOLD3, LIMITED --查询
      INTO H1, H2, H3, L
      FROM EACH_OWNER
     WHERE OWNER_ID = U_ID;
  
    IF L = 'N' THEN
   
      ST_DATE := SYSDATE;
      ED_DATE := ST_DATE + 15;
   
      SELECT USER_ID, USER_NAME
        INTO OR_ID, OR_NAME
        FROM USERS
       WHERE USER_ID = U_ID;
      SELECT BOOK_ID, BOOK_NAME
        INTO BK_ID, BK_NAME
        FROM BOOK
       WHERE BOOK_ID = B_ID;
      INSERT INTO LOAN  --插入
      VALUES
        (SQ_LOAN_ID.NEXTVAL,
         OR_ID,
         OR_NAME,
         BK_ID,
         BK_NAME,
         ST_DATE,
         ED_DATE);
      UPDATE BOOK SET STATUS = '借出' WHERE BOOK_ID = B_ID;
      COMMIT;
   
      DBMS_OUTPUT.PUT_LINE('YOU HAVE BORROWED THE BOOK SUCCESSFULLY!');
   
      IF H1 = 0 THEN
        UPDATE EACH_OWNER SET HOLD1 = B_ID WHERE OWNER_ID = U_ID;
        DBMS_OUTPUT.PUT_LINE('11111111');
      ELSIF H2=0 THEN
        UPDATE EACH_OWNER SET HOLD2 = B_ID WHERE OWNER_ID = U_ID;--更新
        DBMS_OUTPUT.PUT_LINE('22222222');
      ELSIF H3=0 THEN
        UPDATE EACH_OWNER
           SET HOLD3 = B_ID
         WHERE OWNER_ID = U_ID;
        DBMS_OUTPUT.PUT_LINE('33333');
      
      END IF;
      
      SELECT HOLD1,HOLD2,HOLD3
      INTO H1,H2,H3 FROM EACH_OWNER
      WHERE OWNER_ID=U_ID;
      
      IF H1<>0 AND H2<>0 AND H3<>0 THEN
      UPDATE EACH_OWNER
      SET LIMITED='Y'
      WHERE OWNER_ID=U_ID;
      END IF;
      COMMIT;
   
    ELSE
      DBMS_OUTPUT.PUT_LINE('YOU HAVE ALREADY OWNED 3 BOOKS!CANNOT OWN ANY MORE!');
   
    END IF;
  
  ELSE
    DBMS_OUTPUT.PUT_LINE('THE BOOK IS ALREADY OWNED BY SOMEONE.PLEASE MAKE SURE THE DETIAL!');
  
  END IF;

EXCEPTION
  WHEN NO_DATA_FOUND THEN
    DBMS_OUTPUT.PUT_LINE('YOU MAY HAVE ENTERED A WRONG USERID OR BOOKID!');
  
END LOAN_BOOK;
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

GMT+8, 2024-5-22 08:04 , Processed in 0.408749 second(s), 45 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表