Oracle集合类型如何输出参数PL存储过程

数据库 Oracle
以下的文章主要介绍的是实现Oracle集合类型的输出参数PL/SQL的存储过程的实际操作步骤。以下就是文章的具体描述。

以下的文章主要是介绍Oracle集合类型的输出参数PL/SQL的存储过程,我们现在的java数据库的关系映射技术在一定程度上是不提倡使用存储过程的,其实存储过程更能发挥数据库的效率。

1 引言

存储过程因其执行效率高、与事务处理的结合、运行更安全等优点,在数据库应用程序中被广泛采用。PL/SQL是用于从各种环境中访问Oracle数据库的一种编程语言,它与数据库服务器集成在一起,PL/SQL编写的存储过程编译效率高,网络系统开销小,同时PL/SQL直观性好,是大多数人的选择。

以Number、Varchar等基本标量类型为输出参数的PL/SQL存 储过程,每个输出参数只能返回一个对应值。而在实际数据库应用程序中,尤其是在进行系统综合查询统计时,往往需要返回二维数组或结果集,这时应考虑在存储 过程中使用集合这种数据结构。对于集合,我们可以一次把许多元素作为一个整体进行操作,也可以对集合中的单个元素进行操作,使用方便、灵活。

2 PL/SQL存储过程及Java程序的编写

2.1 索引表作为输出参数

索引表是无约束的,其大小的***限制(除可用内存外)就是它的关键字BINARY_INTEGER类型所能表示数值的约束(-2147483647...+2147483647),其元素不需要按任何特定顺序排列。在声明时,我们不需要指定其大小,而且对索引表的元素可以直接赋值,不用初始化,可见使用索引表极其方便。

2.1.1存储过程的编写

我们可以在PL/SQL语句块中定义索引表,但作为输出参数的索引表,必须要在包(package)里定义,方法如下:

  1. create or replace package out_param is  

定义了元素是varchar2类型的一个索引表类型

  1. type out_index_table_typ is table of varchar2(50) 
    index by binary_integer;  
  2. end out_param; 

接下来就可以在pl/sql存储过程里引用在包里定义的索引表类型:

  1. create or replace procedure testPro1
    (in_param in varchar2,o_table out out_param. out_index_table_typ ) is  
  2. begin  

这里略去程序体

  1. end testPro1;  

其中,返回的索引表类型前必须用包名加上句点来引用out_param. out_index_table_typ ,以上的相关内容就是对Oracle集合类型输出参数的PL/SQL存储过程的介绍,望你能有所收获。

【编辑推荐】

  1. Oracle数据库中经常使用的启动方式介绍
  2. Oracle数据库中3种常用的关闭方式
  3. Oracle11g认证考试的3个主要途径
  4. Oracle存储过程的编写经验总结
  5. 闲谈Oracle应用数据库系统设计与开发简介

 

责任编辑:佚名 来源: 博客园
相关推荐

2009-03-26 10:46:58

OraclePL、SQL存储过程

2010-10-25 15:56:02

Oracle PLSQL过程调试

2009-03-09 16:39:19

PL SQLOracle过程调试

2011-04-15 10:56:22

2011-08-24 16:56:54

OracleArray类型存储过程

2011-08-25 09:31:43

JDBC调用Oracl

2010-04-16 11:39:56

Oracle存储过程

2010-06-02 10:09:29

MySQL 存储过程参

2010-04-16 11:03:02

Oracle存储过程

2010-05-10 10:46:07

Oracle存储过程

2011-04-12 11:12:20

Oracle存储过程

2011-08-23 13:14:05

JDBC带输出参数的存储过程

2009-03-25 10:48:08

存储银行Oracle

2011-04-13 09:45:15

Oracle存储

2010-04-07 13:12:25

Oracle存储过程

2010-04-16 10:11:20

Oracle存储过程

2010-11-19 11:32:25

Oracle存储过程

2010-04-30 08:47:22

Oracle分页存储

2010-05-07 13:03:01

Oracle通过存储过

2012-03-08 10:18:33

JavaOracle
点赞
收藏

51CTO技术栈公众号