1、为了提高存储过程的健壮性,避免运行错误,当建立存储过程时应包含异常处理部分。

2、异常(EXCEPTION)是一种PL/SQL标识符,包括预定义异常、非预定义异常和自定义异常;

3、预定义异常是指由PL/SQL提供的系统异常;非预定义异常用于处理与预定义异常无关的Oracle错误(如完整性约束等);自定义异常用于处理与Oracle错误的其他异常情况。

4、RAISE_APPLICATION_ERROR用于自定义错误消息,并且消息号必须在-20000~-20999之间

命名的系统异常    产生原因

access_into_null   未定义对象

case_not_found    case中若未包含相应的when,并且没有设置

collection_is_null   集合元素未初始化

curser_already_open   游标已经打开

dup_val_on_index   唯一索引对应的列上有重复的值

invalid_cursor    在不合法的游标上进行操作

invalid_number    内嵌的 sql 语句不能将字符转换为数字

no_data_found    使用 select into 未返回行,或应用索引表未初始化的

too_many_rows    执行 select into 时,结果集超过一行

zero_divide    除数为 0

subscript_beyond_count   元素下标超过嵌套表或varray的最大值

subscript_outside_limit   使用嵌套表或 varray 时,将下标指定为负数

value_error    赋值时,变量长度不足以容纳实际数据

login_denied    pl/sql 应用程序连接到 oracle 数据库时,提供了不正确的用户名或密码      确的用户名或密码

not_logged_on    pl/sql 应用程序在没有连接 oralce 数据库的情况下访问数据      问数据

program_error    pl/sql 内部问题,可能需要重装数据字典& pl./sql系统包     统包

rowtype_mismatch          主游标变量与 pl/sql 游标变量的返回类型不兼容

self_is_null    使用对象类型时,在 null 对象上调用对象方法

storage_error    运行 pl/sql 时,超出内存空间

sys_invalid_id    无效的 rowid 字符串

timeout_on_resource   oracle 在等待资源时超时

--自定义异常处理

CREATE OR REPLACE PROCEDURE stu_proc

(

--多个用逗号隔开

v_id IN NUMBER

) IS

--多个用分号隔开

v_max_id NUMBER;

v_name VARCHAR2(20);

v_raise EXCEPTION;

BEGIN

SELECT MAX(a.id) INTO v_max_id FROM student a;

IF v_id>v_max_id THEN

RAISE v_raise;

END IF;

SELECT o.sname INTO v_name FROM student o WHERE o.id=v_id;

dbms_output.put_line('学生名称为:'||v_name);

EXCEPTION

WHEN v_raise THEN

RAISE_APPLICATION_ERROR(-20010, 'v_id not exists!');

WHEN NO_DATA_FOUND THEN

RAISE_APPLICATION_ERROR(-20011, 'ERROR:不存在!');

END stu_proc;

Oracle存储过程的异常处理的更多相关文章

  1. Oracle 存储过程异常处理

    Oracle 存储过程异常处理 1.异常的优点    如果没有异常,在程序中,应当检查每个命令的成功还是失败,如  BEGIN  SELECT ...  -- check for ’no data f ...

  2. 【转】几个常用的Oracle存储过程

    http://blog.bossma.cn/database/some-oracle-storing-process/ 几个常用的Oracle存储过程 发布时间:2008年1月6日 / 分类:Data ...

  3. ORACLE存储过程笔记1

    ORACLE存储过程笔记1 一.基本语法(以及与informix的比较)   create [or replace] procedure procedure_name (varible {IN|OUT ...

  4. oracle存储过程加密

    引言:平时大家在做项目的时候,经常会遇到把Oracle存储过程带到项目现场来测试系统.这时如果想对自己的存储过程进行保密,不使别人看到源代码,就可以对已有的存储过程进行加密保护.顾名思义,就是对Ora ...

  5. Oracle 存储过程_(收集)

    oracle 存储过程的基本语法 1.基本结构 CREATE OR REPLACE PROCEDURE 存储过程名字(    参数1 IN NUMBER,    参数2 IN NUMBER) IS变量 ...

  6. Oracle 存储过程学习笔记

    1.存储过程简单实例 CREATE OR REPLACE PROCEDURE 存储过程名称 (参数in,参数out) AS -- 变量声明,每个声明用分号结束.可以在声明的同时初始化 name ); ...

  7. 转:ORACLE存储过程笔记1----基本语法(以及与informix的比较)

    一.基本语法(以及与informix的比较)   create [or replace] procedure procedure_name (varible {IN|OUT|IN OUT} type) ...

  8. oracle 存储过程调用 执行

    oracle 存储过程调用 博客分类: 数据库相关   oracle存储过程 2011年02月11日 星期五 14:47 SQL中调用存储过程语句: call procedure_name(); 调用 ...

  9. oracle存储过程和游标的使用

    oracle存储过程和游标的使用 (2011-04-19 14:52:47) 转载▼ 游标: 用来查询数据库,获取记录集合(结果集)的指针,我们所说的游标通常是指显式游标,因此从现在起没有特别指明的情 ...

随机推荐

  1. OGG 12.3中支持系统procedure复制的几点说明

    如果需要同步系统级别的过程和package,则需要满足以下条件: 要求使用OGG12.3及以后的版本 需要使用oracle db12.2及以后的版本 需要使用集成抽取和集成投递 在DBA_GG_SUP ...

  2. hashcat使用命令简介

    1.指定HASH类型 在HashCat中--hash-type ?参数可以指定要破解的HASH类型,运行hashcat主程序加上--help参数,在* Generic hash types:中可以看到 ...

  3. iOS项目之“返回”手势操作相关

    在程序中,总会设置“返回”按钮,但不可能在每一个控制器中都去设置一次“返回”按钮,那如何设置全局的“返回”按钮呢? 首先自定义一个导航控制器,在tabBarController中添加子控制器时,使用这 ...

  4. The logback manual #03# Configuration

    索引 Configuration in logback Automatically configuring logback Automatic configuration with logback-t ...

  5. Eureka-zookeeper的服务发现替代方案

    参考: https://my.oschina.net/thinwonton/blog/1622905 http://www.open-open.com/lib/view/open14269407225 ...

  6. mysql 水平分表技术

    这里做的是我的一个笔记. 水平分表比较简单, 理解就是: 合并的表使用的必须是MyISAM引擎 表的结构必须一致,包括索引.字段类型.引擎和字符集 数据表 user1 CREATE TABLE `us ...

  7. Linux下的查找技巧

    Find知识点: -mtime ——修改时间 -ctime ——创建时间 -atime ——访问时间 mtime 举例说明: -mtime n : n为数字,意思为在n天之前的“一天之内”被更改过内容 ...

  8. 识别简单的答题卡(Bubble sheet multiple choice scanner and test grader using OMR, Python and OpenCV——jsxyhelu重新整编)

    该博客转自www.pyimagesearch.com,进行了相关修改补充. Over the past few months I've gotten quite the number of reque ...

  9. TensorFlow 生成 .ckpt 和 .pb

    原文:https://www.cnblogs.com/nowornever-L/p/6991295.html 1. TensorFlow  生成的  .ckpt 和  .pb 都有什么用? The . ...

  10. bzoj 4540 [HNOI 2016] 序列 - 莫队算法 - Sparse-Table - 单调栈

    题目传送门 传送点I 传送点II 题目大意 给定一个长度为$n$的序列.询问区间$[l, r]$的所有不同的子序列的最小值的和. 这里的子序列是连续的.两个子序列不同当且仅当它们的左端点或右端点不同. ...