- 浏览: 502299 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
caipeiming:
可以使用array的indexOf方法,参考JavaScrip ...
js-判断元素是否存在于array数组中 -
zhangyaochun:
这个不错,新属性哦~
html5新特性-- <a>标签新属性download -
housheng33:
空间和时间星型-雪花-ER一范式-二范式-三范式
浅谈多维模型 -
housheng33:
对不起,我已经24岁了。我已经没有能力和你谈那一场天真而不计得 ...
对不起,我已经24岁了。我已经没有能力和你谈那一场天真而不计得失的恋爱了。 -
zhangyaochun:
这篇整理的不错
js-清空array数组
Oracle中异常分为预定义异常,非预定义异常和自定义异常三种。
预定义异常:
1 CURSOR_ALREADY_OPEN该异常触发ORA-06511错误。
当程序中的一个游标已经执行了打开操作,如果开发人员试图再一次打开这个已经打开的游标时,将触发该异常。
2 INCALID_CURSOR该异常触发ORA-01001错误。
当试图对一个尚未打开的游标执行任何操作,如打开该非法的游标执行赋值操作,或者关闭未打开的游标时,将触发该异常。
3 NO_DATA_FOUND该异常触发ORA-01403错误。
当读取一个游标进行赋值操作(SELECT INTO操作)时,如果未返回任何行,将触发该异常。
4 TOO_MANY_ROWS该异常触发ORA-01422错误。
上面是没有返回记录,这里是返回多条记录的时候会触发该异常。
5 VALUE_ERROR该异常触发ORA-06502错误。
当在PL/SQL程序中执行赋值操作时,如果右边值的长度大于左边变量的长度,将触发该异常。
6 DUP_VAL_ON_INDEX该异常触发ORA-00001错误。
若表的每一列声明为主键,或具有惟一性,如果对该列插入重复的值时将触发该异常。
7 CASE_NOT_FOUND该异常触发ORA-06592错误。
在CASE语句中,如果CASE语句的条件在WHEN子句中没有找到对应的条件分支,且该CASE语句不包含ELSE分支,将触发该异常。
8 ZERO_DIVIDE该异常触发ORA-01476错误。
当在程序中使用0作为除数进行运算时,将触发该异常。
9 INVALID_NUMBER该异常触发ORA-01722错误。
数字或值错误,或字符到数值的转换错误。
10 ACCESS_INTO_NULL该异常触发ORA-06530错误。
当程序中的对象还没有先进行对象初始化的操作,就直接为对象的属性赋值,将触发该异常。
11 COLLECTION IS NULL该异常触发ORA-06531错误。
在给集合元素赋值前,必须先初始化该集合元素,否则触发该异常。
12 SUBSCRIPT_BEYOND_COUNT该异常触发ORA-06533错误。
当使用复合数据类型时,如果下标越界触发该异常。
13 SUBSCRIPT_OUTSIDE_LIMIT该异常触发ORA-06532错误。
当使用复合数据类型时,如果下标为负值时触发该异常。
14 LONIN_DENIED该异常触发ORA_01017错误。
当PL/SQL连接数据库时,如果密码错误,将触发该异常。
15 NOT_LOGGED_ON该异常触发ORA-01012错误。
如果PL/SQL没有连接数据库,程序运行将触发该异常。
16 PROGRAM_ERROR该异常触发ORA-06501错误。
如果出现该异常,则表示PL/SQL的内部问题。用户可能需要重新安装数据字典和PL/SQL系统包。
17 ROWTYPE MISMATCH该异常触发ORA-06504错误。
在赋值时,如果宿主游标变量和PL/SQL游标变量的返回类型不兼容,将触发该异常。
18 SELF_IF_NULL该异常触发ORA-30625错误。
在使用对象类型时,如果在NULL示例上调用成员方法将触发该异常。
19 STORAGE_ERROR该异常触发ORA-06500错误。
当PL/SQL块运行时,如果走出内在空间或内在被损坏则触发该异常。
20 SYS_INVALID_ROWID该异常触发ORA-01410错误。
当将字符串转变为ROWID时,如果使用了无效的字符串则触发该异常。
21 TIMEOUT_ON_RESOURCE该异常触发ORA-00051错误。
Oracle在等待资源时出现超时错误时将触发该异常。
22 ORA-04021Oracle在等待资源时出现超时错误,该资源可能被其它session锁住,此时将触发该异常。
23 ORA-01791 不是Selected表达式.
24 ORA-01002: fetch out of sequence当游标中数据集已经取完,然后再一次进行FETCH操作时将触发该异常。
25 PLS-00382: expression is of wrong type表达式类型错误。即在代码中赋予操作的左右两边的类型不等。
非预定义异常:
使用非预定义异常的步骤如下:定义异常 -> 关联异常和错误 -> 引用例外
当定义Oracle错误和例外之间的关联关系时,要使用伪过程EXCEPTION_INTI。
自定义异常:
使用预定义异常和非预定义异常,程序可以捕获Oracle错误,并且在出现Oracle错误时自动触发对应的异常。但是在实际应用中,可能还会 遇到其它错误,这时,可以为特定的情况自定义异常,不过需要显示触发该异常:通过定义异常,然后关联异常和错误,显示触发异常,最后在EXCEPTION 中处理该异常。
例外函数:
1 SQLCODE,SQLERRM在PL/SQL块中出现Oracle错误时,通过使用例外函数可以取得错误号以及相关的错误消息。
SQLCODE 返回Oracle错误号。
SQLERRM 返回错误号对应的错误消息。
2 RAISE_APPLICATION_ERROR在存储过程,函数和包中使用RAISE_APPLICATION_ERROR可以自定义错误号和消息。
raise_application_error:用于自定义错误消息(用于程序段中)
语法:
raise_application_error(error_number,message[,{TRUE | FALSE}]);
error_number : 错误号,范围是: -20000 ~ -20999之间的负整数;
message : 错误消息,长度不能超过2048字节;
第三个可靠选参数,如果TRUE,该错误会被放在先前错误堆栈中;如果FALSE(默认),则替换先前所有错误.
http://blog.csdn.net/jiushuai/article/details/6560439
http://czmmiao.iteye.com/blog/1836709
预定义异常:
1 CURSOR_ALREADY_OPEN该异常触发ORA-06511错误。
当程序中的一个游标已经执行了打开操作,如果开发人员试图再一次打开这个已经打开的游标时,将触发该异常。
2 INCALID_CURSOR该异常触发ORA-01001错误。
当试图对一个尚未打开的游标执行任何操作,如打开该非法的游标执行赋值操作,或者关闭未打开的游标时,将触发该异常。
3 NO_DATA_FOUND该异常触发ORA-01403错误。
当读取一个游标进行赋值操作(SELECT INTO操作)时,如果未返回任何行,将触发该异常。
4 TOO_MANY_ROWS该异常触发ORA-01422错误。
上面是没有返回记录,这里是返回多条记录的时候会触发该异常。
5 VALUE_ERROR该异常触发ORA-06502错误。
当在PL/SQL程序中执行赋值操作时,如果右边值的长度大于左边变量的长度,将触发该异常。
6 DUP_VAL_ON_INDEX该异常触发ORA-00001错误。
若表的每一列声明为主键,或具有惟一性,如果对该列插入重复的值时将触发该异常。
7 CASE_NOT_FOUND该异常触发ORA-06592错误。
在CASE语句中,如果CASE语句的条件在WHEN子句中没有找到对应的条件分支,且该CASE语句不包含ELSE分支,将触发该异常。
8 ZERO_DIVIDE该异常触发ORA-01476错误。
当在程序中使用0作为除数进行运算时,将触发该异常。
9 INVALID_NUMBER该异常触发ORA-01722错误。
数字或值错误,或字符到数值的转换错误。
10 ACCESS_INTO_NULL该异常触发ORA-06530错误。
当程序中的对象还没有先进行对象初始化的操作,就直接为对象的属性赋值,将触发该异常。
11 COLLECTION IS NULL该异常触发ORA-06531错误。
在给集合元素赋值前,必须先初始化该集合元素,否则触发该异常。
12 SUBSCRIPT_BEYOND_COUNT该异常触发ORA-06533错误。
当使用复合数据类型时,如果下标越界触发该异常。
13 SUBSCRIPT_OUTSIDE_LIMIT该异常触发ORA-06532错误。
当使用复合数据类型时,如果下标为负值时触发该异常。
14 LONIN_DENIED该异常触发ORA_01017错误。
当PL/SQL连接数据库时,如果密码错误,将触发该异常。
15 NOT_LOGGED_ON该异常触发ORA-01012错误。
如果PL/SQL没有连接数据库,程序运行将触发该异常。
16 PROGRAM_ERROR该异常触发ORA-06501错误。
如果出现该异常,则表示PL/SQL的内部问题。用户可能需要重新安装数据字典和PL/SQL系统包。
17 ROWTYPE MISMATCH该异常触发ORA-06504错误。
在赋值时,如果宿主游标变量和PL/SQL游标变量的返回类型不兼容,将触发该异常。
18 SELF_IF_NULL该异常触发ORA-30625错误。
在使用对象类型时,如果在NULL示例上调用成员方法将触发该异常。
19 STORAGE_ERROR该异常触发ORA-06500错误。
当PL/SQL块运行时,如果走出内在空间或内在被损坏则触发该异常。
20 SYS_INVALID_ROWID该异常触发ORA-01410错误。
当将字符串转变为ROWID时,如果使用了无效的字符串则触发该异常。
21 TIMEOUT_ON_RESOURCE该异常触发ORA-00051错误。
Oracle在等待资源时出现超时错误时将触发该异常。
22 ORA-04021Oracle在等待资源时出现超时错误,该资源可能被其它session锁住,此时将触发该异常。
23 ORA-01791 不是Selected表达式.
24 ORA-01002: fetch out of sequence当游标中数据集已经取完,然后再一次进行FETCH操作时将触发该异常。
25 PLS-00382: expression is of wrong type表达式类型错误。即在代码中赋予操作的左右两边的类型不等。
非预定义异常:
使用非预定义异常的步骤如下:定义异常 -> 关联异常和错误 -> 引用例外
当定义Oracle错误和例外之间的关联关系时,要使用伪过程EXCEPTION_INTI。
自定义异常:
使用预定义异常和非预定义异常,程序可以捕获Oracle错误,并且在出现Oracle错误时自动触发对应的异常。但是在实际应用中,可能还会 遇到其它错误,这时,可以为特定的情况自定义异常,不过需要显示触发该异常:通过定义异常,然后关联异常和错误,显示触发异常,最后在EXCEPTION 中处理该异常。
DECLARE l_error_message VARCHAR2(200); e_user_exception EXCEPTION; BEGIN ** ** ** ** **; IF '出现错误' THEN l_error_message := '定义错误信息'; RAISE e_user_exception; END IF; EXCEPTION WHEN e_user_exception THEN raise_application_error(-20001, l_error_message); END;
例外函数:
1 SQLCODE,SQLERRM在PL/SQL块中出现Oracle错误时,通过使用例外函数可以取得错误号以及相关的错误消息。
SQLCODE 返回Oracle错误号。
SQLERRM 返回错误号对应的错误消息。
DECLARE v_ename emp.ename%TYPE; BEGIN SELECT ename INTO v_ename FROM emp WHERE sal = &v_sal; dbms_output.put_line('雇员名:' || v_ename); EXCEPTION WHEN NO_DATA_FOUND THEN dbms_output.put_line('不存在工资为' || v_sal || '雇员'); WHEN OTHERS THEN dbms_output.put_line('错误号' || SQLCODE); dbms_output.put_line(SQLERRM); END;
2 RAISE_APPLICATION_ERROR在存储过程,函数和包中使用RAISE_APPLICATION_ERROR可以自定义错误号和消息。
raise_application_error:用于自定义错误消息(用于程序段中)
语法:
raise_application_error(error_number,message[,{TRUE | FALSE}]);
error_number : 错误号,范围是: -20000 ~ -20999之间的负整数;
message : 错误消息,长度不能超过2048字节;
第三个可靠选参数,如果TRUE,该错误会被放在先前错误堆栈中;如果FALSE(默认),则替换先前所有错误.
CREATE OR REPLACE PROCEDURE raise_comm(eno NUMBER,commission NUMBER) IS v_comm emp.comm%TYPE; BEGIN SELECT comm INTO v_comm FROM emp WHERE emp = eno; IF v_comm IS NULL THEN raise_application_error(-20001, '该员工无补助.'); END IF; EXCEPTION WHEN NO_DATA_FOUND THEN dbms_output.put_line('该雇员不存在.'); END;
http://blog.csdn.net/jiushuai/article/details/6560439
http://czmmiao.iteye.com/blog/1836709
发表评论
-
Oracle中Merge Into 代替Insert/Update的应用
2015-01-19 10:37 2101在进行SQL语句编写时,我们经常会遇到大量的同时进行Inser ... -
oracle uuid函数
2014-05-06 20:13 2179SYS_GUID (),是Oracle 8i 后提供的函数。S ... -
命令行新建job报错ORA-01008
2014-04-29 20:06 1114# 命令行新建 job 错误: ORA-01008 并非所有变 ... -
ORACLE DBMS_JOB包参数之--interval
2014-04-29 14:09 862Internal参数是一个表示Oracle合法日期表达式的字符 ... -
oracle job 简介
2014-04-28 15:16 530登陆当前用户执行[code="sql" ... -
oracle 如何查找和kill 对应的job进程
2014-04-28 14:50 1198查找当前被锁住的进程: SELECT object_name ... -
pl/sql记住用户名和密码
2014-04-23 11:06 764在使用PL/SQL Developer时,为了工作方便希望PL ... -
由复合指标计算引起的oracle累乘
2014-03-26 19:01 1278项目中复合指标由配置 ... -
oracle自定义函数
2014-03-24 14:02 700http://blog.csdn.net/smartsmile ... -
oracle字符型函数INITCAP NLS_INITCAP
2014-03-20 18:08 3440INITCAP(c1字符型表达式) 【功能】返回字符串并将字 ... -
oracle一些常用的系统表
2014-03-20 17:38 660dba_开头 dba_users 数 ... -
oracle查看数据库信息
2014-04-02 15:10 8001.查看所有用户:select * from dba_us ... -
powerDesigner使用小技巧
2014-03-18 16:49 8871. 将所有名词转化为大写 tools→Model O ... -
PowerDesigner comment与name互相复制
2014-02-28 18:11 672在使用PowerDesigner对数据库进行概念模型和物理模型 ... -
sql优化--识别’低效执行’的SQL语句
2014-02-18 19:06 1694oracle中有两个重要的视 ... -
oracle存储过程遍历游标
2014-02-18 18:09 0create or replace procedure tes ... -
powerDesigner 生成建表sql同时生成注释
2014-01-27 14:19 18545默认打开powerDesigner时,创建table对应的自动 ... -
【转】恢复ORACLE被误更新或删除数据的办法
2014-01-19 18:39 2503有时候我们在操作ORACLE数据库的时候,可能由于SQL写错了 ... -
oracle11g向10g指定版本数据迁移
2013-11-27 15:00 8451. 命令行cmd执行导出语句: expdp dmuser/d ... -
oracle 中实现四舍六入五成双
2013-11-14 16:31 3588不同于以往‘四舍五入’造成数据偏差大,关于’四舍六入五成双‘百 ...
相关推荐
Oracle PL/SQL是一种强大的编程语言,它结合了SQL的数据处理能力与PL的程序设计特性,是Oracle数据库系统中用于创建存储过程、函数、触发器和包的主要工具。在这个"Oracle PL/SQL实战(待续)"的主题中,我们将深入...
PL/SQL是Oracle数据库的内置编程语言,由块构成,包括声明部分、执行部分和异常处理部分。块可以是匿名块(即直接在SQL*Plus或其他工具中编写的一次性执行的代码),也可以是存储过程、函数、触发器、包等可重用的...
ORACLE PL/SQL是从入门到精通的专业知识,涵盖了数据库开发与管理的多个方面,包括触发器、过程、函数、软件包、异常处理、游标、循环、分支、变量使用、数据库安装等关键知识点。 触发器是数据库中用来保证数据...
《Oracle PL/SQL程序设计(第5版)(套装上下册)》基于Oracle数据库11g,从PL/SQL编程、PL/SQL程序结构、PL/SQL程序数据、PL/SQL中的SQL、PL/SQL应用构建、高级PL/SQL主题这6个方面详细系统地讨论了PL/SQL以及如何...
在"Oracle PL/SQL实例精解 数据库建立代码"中,我们将深入探讨如何在Oracle数据库中使用PL/SQL来构建一个名为"student"的模式,这包括创建数据库对象如表、索引,以及填充样本数据。 首先,"student"模式可能包含一...
4. **游标**:游标是PL/SQL中处理单行或多行结果集的关键工具。通过游标,程序员可以逐行处理查询结果,进行更新、插入或删除操作。 5. **异常处理**:Oracle PL/SQL提供了丰富的异常处理机制,使得程序能够优雅地...
《Oracle PL/SQL程序设计(第5版)》是一本全面介绍Oracle 11g中PL/SQL特性的书籍,适合数据库开发人员、管理员及相关从业人员阅读。本书不仅覆盖了PL/SQL的基础知识,还包括了大量的实战经验和高级主题,对于想要深入...
Oracle 10g PL/SQL 是Oracle数据库系统中用于创建和管理存储过程、函数、触发器等数据库对象的编程语言。本教程旨在为初学者提供一个全面的学习平台,同时也为经验丰富的开发者提供参考资料。PL/SQL是Oracle特有的...
在Oracle数据库环境中,PL/SQL是开发高效、可靠和可维护的数据库应用程序的关键工具。以下是对"Oracle PL/SQL学习官方教材"中可能包含的主要知识点的详细解释: 1. **基础概念**:首先,教材会介绍PL/SQL的基本概念...
《Oracle PL/SQL专家指南-高级PL/SQL解决方案的设计与开发》是一本深入探讨Oracle数据库中的PL/SQL编程的专业书籍。PL/SQL是Oracle数据库特有的编程语言,它结合了SQL的查询能力与过程式编程语言的功能,使得数据库...
Oracle PL/SQL是一种强大的编程语言,它结合了SQL的数据库操作能力和Procedural Language的编程结构,用于在Oracle数据库环境中创建复杂的应用程序。在"Oracle PL/SQL实例精讲student数据库模式"中,我们将深入探讨...
Oracle PL/SQL 是一种高级编程语言,用于开发 Oracle 数据库中的存储过程、函数和触发器。PL/SQL language 提供了强大的编程能力,可以实现复杂的业务逻辑,并且与 Oracle 数据库紧密集成。 一、Oracle 简介 ...
本书是一本逐步分解的,详尽的pl/sql编程教程,使用真实场景的试验、范例和练习来介绍读者所需的pl/sql编程技能,涵盖oracle 11g的最新特性。作者的写作手法源自于在哥伦比亚大学教授pl/sql编程技术的经验,深度...
oracle PL/SQL pdf学习资料oracle PL/SQL pdf学习资料oracle PL/SQL pdf学习资料oracle PL/SQL pdf学习资料oracle PL/SQL pdf学习资料
本书是关于Oracle PL/SQL编程的权威指南,被认为是数据库社区中最优秀的Oracle编程书籍之一。第五版涵盖了Oracle Database 11g Release 2的所有新功能,并提供了大量示例代码,包括简单的示例到复杂的完整应用程序。...
2. **游标**:游标是PL/SQL中处理单行记录的重要工具,允许程序逐行处理结果集。压缩包可能包含如何声明、打开、读取和关闭游标的例子。 3. **存储过程和函数**:存储过程和函数是PL/SQL的核心,它们封装了业务逻辑...
Oracle PL/SQL是一种强大的编程语言,用于在Oracle数据库环境中构建复杂的业务逻辑和数据处理任务。Steven Feuerstein,被誉为Oracle PL/SQL语言的大师,分享了他在这一领域的关键最佳实践和重要特性。这篇PPT旨在...
总之,Oracle PL/SQL语言初级教程将引导初学者逐步掌握PL/SQL的基础知识,包括语法、数据类型、函数、表和视图的管理、完整性约束、过程和函数、操作控制以及异常处理。通过学习,开发者可以编写出高效、稳定的...
本书的第四版详细介绍了Oracle PL/SQL的各种核心概念和技术,帮助读者深入理解和掌握如何在Oracle环境中有效地编写和管理PL/SQL代码。 PL/SQL是Oracle数据库提供的一个内置编程语言,它将SQL的查询能力与过程编程...