- 浏览: 176933 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
SanFrans:
很不错的资料,谢谢分享
Oracle EBS 常用表 查询语句 -
Vity:
楼主坚持下去
Android学习指南基础--第一讲:Android开发环境的搭建【附件有图】 -
拥抱变化之美:
楼主的治学精神值得称赞。
C# 4.0 并行计算部分(附件有图) -
overloving:
fangjindan 写道
这个是绝对可行的哈,我测试通 ...
Linux下Oracle存储过程调用Java程序(含外部包) -
fangjindan:
Linux下Oracle存储过程调用Java程序(含外部包)
--######################################-- --错误和异常 --王林 2012.07.06 --######################################-- --三种编译错误消息: /* 一种是错误发生在前一语句行时指向语句行的第一列;另一种是在错误发生在同一行时指向错误发生的列或后一列;还有一种是指向声明块错误,在消息底部提供实际错误的行号。 */ --######################################-- --1.错误发生在前一行,通常是由于缺少语句终止符END保留字前缺少词汇单元,这里指分号 BEGIN DBMS_OUTPUT.put_line( 'Hello World' ) END; -- ORA-06550: line 4, column 1: PLS-00103: Encountered the symbol "END" when expecting one of the following: := . ( % ; The symbol ";" was substituted for "END" to continue. SQL> --######################################-- --2.错误发生在当前行,变量B前缺少词汇单元 DECLARE a NUMBER := 0; b NUMBER; c NUMBER; BEGIN c := a b; END; -- ORA-06550: line 7, column 12: PLS-00103: Encountered the symbol "B" when expecting one of the following: . ( * @ % & = - + ; < / > at in is mod remainder not rem <an exponent (**)> <> or != or ~= >= <= <> and or like like2 like4 likec between || multiset member submultiset The symbol "." was substituted for "B" to continue. SQL> --######################################-- --3.应出现赋值运算符的地方出现了比较运算符 DECLARE a NUMBER; BEGIN a = 1; END; -- ORA-06550: line 5, column 7: PLS-00103: Encountered the symbol "=" when expecting one of the following: := . ( @ % ; The symbol ":= was inserted before "=" to continue. SQL> --######################################-- --4.错误发生在声明块,只是说明声明块中有错误 DECLARE a CHAR := 'AB'; BEGIN DBMS_OUTPUT.put_line( '[' || a || ']' ); END; -- ORA-06502: PL/SQL: numeric or value error: character string buffer too small ORA-06512: at line 3 SQL> --######################################-- --一、异常类型和作用域 --1.局部异常块捕获和管理局部错误,异常块只管理那种错误,其它异常将被忽略并被抛给SQL*Plus会话。 DECLARE a VARCHAR2 (1); b VARCHAR2 (2) := 'ab'; BEGIN a := b; EXCEPTION WHEN value_error THEN DBMS_OUTPUT.put_line('you are wrong.'); END; --2.内部块中引发的错误,将被外部块异常处理程序捕获。 DECLARE a NUMBER; BEGIN DECLARE b VARCHAR2 (2); BEGIN --引发的错误是NO_DATA_FOUND异常 SELECT 1 INTO b FROM dual WHERE 1 = 2; --引发的错误是赋值错误 a := b; EXCEPTION --内部块只检查VALUE_ERROR异常,因为他是特殊的捕获块 WHEN value_error THEN DBMS_OUTPUT.put_line( 'inner wrong.' ); END; EXCEPTION --外部块捕获普通的OTHERS异常 WHEN OTHERS THEN DBMS_OUTPUT.put_line( 'outer wrong.[' || SQLERRM || ']' ); END; --3.在无异常的情况下可手动引发用户自定义的异常。 DECLARE a NUMBER; e EXCEPTION; BEGIN DECLARE b VARCHAR2 (2) := 'AB'; BEGIN --RAISE语句将控制传递给局部异常处理程序。 RAISE e; EXCEPTION WHEN OTHERS THEN --试图将多字符字面值赋给一个字符变量,这引发value_error异常。 a := b; DBMS_OUTPUT.put_line( '1 wrong.' ); END; EXCEPTION WHEN OTHERS THEN DBMS_OUTPUT.put_line( '2 wrong.[' || SQLCODE || ']' ); END; --4.声明块异常 --声明块中的运行时赋值错误不是由局部异常块捕获 DECLARE a VARCHAR2 (1) := '&1'; BEGIN DBMS_OUTPUT.put_line( 'value :' ||a ); EXCEPTION --不起作用 WHEN OTHERS THEN DBMS_OUTPUT.put_line( 'local exception caught.' ); END; -- --将声明错误封装到另一个PL/SQL中 --如果赋值两个字符的字符串 这一错误将被外部异常块捕获 BEGIN DECLARE a VARCHAR2 (1) := '&1'; BEGIN DBMS_OUTPUT.put_line( '1 ' || a); EXCEPTION WHEN OTHERS THEN DBMS_OUTPUT.put_line( '2 '); END; EXCEPTION WHEN OTHERS THEN DBMS_OUTPUT.put_line( '3 '); END; --######################################-- --二、用户自定义异常 --声明exception变量时有两种选择:声明变量并用名称来引用他和声明变量并将他与有效的Oracle错误代码映射。 --前者要求使用普通的OTHERS异常捕获用户自定义异常,后者要为单独的错误构建特定的WHEN块。 --通过调用RAISE_APPLICATION_ERROR函数可构建动态异常。在构建动态异常时可以使用-20000到-20999范围 --的数字。如果使用动态异常,就在运行时指派错误消息,他们也不要求事先声明exception变量。通过声明异常变量可以 --提高动态异常的有用性,同时,他们也增加了捕获异常的方式。 -- --1.声明用户自定义的异常 DECLARE e EXCEPTION; BEGIN RAISE e; DBMS_OUTPUT.put_line( 'can not get there '); EXCEPTION WHEN OTHERS THEN --默认情况下,所有用户定义的异常都只有一个SQLCODE值1 IF SQLCODE = 1 THEN DBMS_OUTPUT.put_line( 'This is a [ ' || SQLERRM || ' ]'); END IF; END; --2.定义一个Excepiton变量并将该异常映射到错误号 --两步的声明过程可以将声明异常并将他映射到数字 DECLARE a VARCHAR2 (20); --第一步声明Exception变量; invalid_userenv_parameter EXCEPTION; --第二步声明PRAGMA。 他是个编译指令,使用它命令编译器以不同的方式执行一些任务。 --EXCEPTION_INIT调用的第一个参数为用户定义的EXCEPTION变量,第二个为有效的错误号。 PRAGMA EXCEPTION_INIT(invalid_userenv_parameter , -2003); BEGIN a := SYS_CONTEXT( 'USERENV' , 'PROXY_PUSHER' ); EXCEPTION WHEN invalid_userenv_parameter THEN DBMS_OUTPUT.put_line(SQLERRM); END; --3.动态的用户定义的异常 --动态的用户定义的异常用于引发异常、赋值和管理是否添加新的错误到错误列表(也就是错误堆栈) --动态异常函数的原型: rasie_application_error( error_number --接受-20000--20999范围的错误号。如果提供其他值引发ORA-21000错误 , error_message --错误消息 [ , keep_errors] --可选 默认FALSE 是否将错误信息添加到任意已有的错误堆栈 ); --没有事先声明用户定义的exception变量的情况下引发一个动态异常 BEGIN raise_application_error(-20001 , 'A not too oritional message'); EXCEPTION WHEN OTHERS THEN DBMS_OUTPUT.put_line(SQLERRM); END; --声明一个exception变量,将用户的错误代码映射到exception变量,然后动态设置消息。 DECLARE e EXCEPTION; PRAGMA EXCEPTION_INIT(e,-20001); BEGIN raise_application_error(-20001 , 'A less than original message.'); EXCEPTION WHEN e THEN DBMS_OUTPUT.put_line(SQLERRM); END;
发表评论
-
Oracle 基本建表语句
2012-11-15 14:12 2189--创建用户 create user han identifi ... -
Oracle EBS Item Import 物料导入 (2) 源代码 成功执行
2012-08-24 10:56 5521CREATE OR REPLACE PACKAGE PkgIm ... -
Oracle 体系结构
2012-08-20 17:29 1010数据库(Database) 数据库是一个数据的集合,不仅 ... -
instr()函数,特殊用法,代替like,in
2012-08-20 17:19 5407--created by : wanglin --cre ... -
Oracle PL/SQL 常用函数总结
2012-08-20 14:02 1650--created by : wanglin --cre ... -
MERGE 使用例子
2012-08-17 17:01 1085--MERGE <Usage Case> --P ... -
内存表使用
2012-08-16 16:46 1719一、 内存表概念 1、PL/SQL表类似于C语言中的 ... -
临时表的使用方法
2012-08-16 15:48 1621临时表的使用方法: 创建 Oracle 临 ... -
Oracle EBS 二次开发 FND_GLOBAL PACKAGE 返回全局变量
2012-08-10 10:52 3037这个包,可以应用于你的 PL/SQL 中! 这个包 ... -
如何定义一个简单的Concurrent Program
2012-08-09 15:08 1036Oracle Apps R12下如何定义一个简单的Hello ... -
SQL Loader 导入Excel数据到Oracle数据库
2012-08-09 08:48 16721、 将需要上传的数据在Excel中整理好,通过“另存为 ... -
Oracle EBS 常用表 查询语句
2012-07-24 11:29 26953ORACLE EBS常用表查询语句 1. ... -
aaa
2012-07-13 14:25 0sdsdfas > http:/ ... -
Oracle_PL_ SQL_ 教程:函数
2012-07-12 21:32 1186--############################# ... -
Oracle_PL_ SQL_ 教程:包
2012-07-12 21:30 1012--############################# ... -
Oracle_PL_ SQL_ 教程:控制语句(条件语句、循环语句)
2012-07-12 21:27 1013--############################# ... -
Linux下Oracle存储过程调用Java程序(含外部包)
2012-07-13 10:03 6813一、描述: 用Java编写了一个导入Excel数 ... -
Oracle_PL_ SQL_ 教程:存储过程
2012-07-11 23:19 2990--############################# ... -
Oracle_PL_ SQL_ 教程:游标
2012-07-11 23:12 942--############################# ... -
Oracle存储过程中调用JAVA程序【转载】
2012-07-11 23:00 1116Oracle存储过程中调用JAVA程序 软件环境 ...
相关推荐
3. **异常处理**:Oracle PL/SQL有内置的异常处理机制,通过BEGIN...EXCEPTION部分来捕获和处理运行时错误,增强了程序的健壮性。 4. **游标**:游标是PL/SQL中处理查询结果集的关键工具,允许逐行访问查询结果,...
Oracle_Sql_Pl_Sql_性能优化.doc Oracle_Sql_Pl_Oracle_Sql_Pl_Sql_性能优化.docSql_性能优化.doc Oracle_Sql_Pl_Sql_性能优化.doc
`pl_sql`标签表明,这份资料可能包含了关于PL/SQL的基础和高级概念,比如块结构(DECLARE, BEGIN, END)、异常处理(TRY-CATCH)、游标处理、动态SQL以及如何调用Oracle数据库的内置函数和包。 `oracle_总结`标签...
- **语法结构**:PL/SQL由声明部分、执行部分和异常处理部分组成,支持变量声明、流程控制语句(如IF-THEN-ELSIF、CASE、FOR循环)以及子程序定义。 - **块结构**:PL/SQL程序由一个或多个块组成,包括匿名块...
1. **Oracle PL/SQL基础**:PL/SQL是Procedural Language/Structured Query Language的缩写,它是Oracle为SQL添加的编程组件,支持流程控制、异常处理和子程序定义。在构建网上商店时,我们可能需要编写存储过程、...
3. **PL/SQL块结构**:PL/SQL由声明部分、执行部分和异常处理部分组成。声明部分定义变量、常量和游标;执行部分包含SQL语句和PL/SQL语句,用于执行实际操作;异常处理部分用于捕获和处理运行时错误。 4. **SQL语句...
4. **块结构**:PL/SQL代码组织在块(BLOCK)中,包括声明部分(DECLARATION)、执行部分(EXECUTION)和异常处理部分(EXCEPTION HANDLING)。 5. **子程序**:包括过程(PROCEDURE)和函数(FUNCTION),它们可以...
Oracle2BPL-SQL.rar_oracle_pl/sql这个压缩包文件可能包含了关于Oracle PL/SQL的基础教程资料,其中的Oracle2BPL-SQL.pdf可能是详细的讲解文本。 Oracle PL/SQL由三部分组成:Procedural Language(过程语言)、...
Oracle PL/SQL是一种在Oracle数据库管理系统中使用的编程语言,它结合了SQL的数据库查询功能和PL/SQL的程序设计元素,使得开发者能够编写复杂的数据库应用。这篇“Oracle PL-SQL入门教程(经典)”旨在帮助初学者掌握...
这些工具包括SQL*Plus,一个命令行工具,用于执行SQL查询、PL/SQL过程和数据库管理任务;Net Configuration Assistant,用于配置网络连接;以及Oracle SQL Developer,一个图形化的数据库管理和开发工具。客户端还...
标题中的“PLSQL.rar_oracle_pl sql_plsql_plsql_java_sql”暗示了这是一个关于Oracle数据库中PLSQL使用的资源包,可能包含了PLSQL的教程、示例代码和与Java集成的相关信息。Oracle数据库是世界上最广泛使用的数据库...
这个压缩包文件"Oracle_Database_11g_SQL_-_Master_SQL_and_PLSQL_in_the_Oracle_Database"似乎包含了一本关于掌握Oracle 11g SQL和PL/SQL的教程资料。 SQL(结构化查询语言)是用于管理和操作数据库的标准语言,而...
Oracle PL/SQL是一种强大的编程语言,它将关系数据库的强大功能与高级编程语法相结合,用于在Oracle数据库环境中构建复杂的业务逻辑和应用程序。Oracle8是PL/SQL的一个早期版本,尽管现在可能已经更新到了更高版本,...
**PL/SQL:Oracle数据库的编程语言** PL/SQL,全称为Procedural Language/Structured Query Language,是Oracle数据库系统中的一个重要的编程组件,它结合了SQL(结构化查询语言)的查询功能与过程性编程语言的特点...
- **块结构**:PL/SQL代码由声明、执行和异常处理三部分组成,包括BEGIN...END块、DECLARE...BEGIN...END块以及匿名块。 - **变量和常量**:PL/SQL支持各种数据类型,如NUMBER、VARCHAR2、DATE等,以及声明变量和...
ORACLE_PL_SQL实例精解 第五部分
ORACLE_PL_SQL实例精解(原书第4版),含书签,共617页
PL/SQL是Oracle数据库系统中用于编写存储过程、函数、触发器等数据库编程的结构化查询语言,扩展了SQL的功能,使得数据库管理员和开发人员能够进行更复杂的数据库操作和管理。Allround Automation PL-SQL Developer...
PL/SQL的基本结构包括声明部分、执行部分和异常处理部分。声明部分用于定义变量、常量和游标;执行部分包含SQL语句和PL/SQL控制结构;异常处理部分则用来捕获和处理运行时错误。理解这些基本结构对于编写健壮的PL/...