Oracle中定义package以及存储过程的使用
2015-02-20 00:39
393 查看
使用scott账户下的dept表;
select * from dept order by deptno;
10 ACCOUNTING NEW YORK
20 RESEARCH DALLAS
30 SALES CHICAGO
40 OPERATIONS BOSTON
为了演示方便,插入一条数据:
insert into dept(deptno, dname, loc) values(50,'SYSTEM', 'NEW YORK');
新插入的记录为:50 SYSTEM NEW YORK
我们主要演示在package中存储过程的返回类型为pipelined table,cursor 和 value三种。
1.返回类型为pipelined table。
create or REPLACE type dept_obj is OBJECT( DEPTNO NUMBER(2,0), DNAME VARCHAR2(14 BYTE) );
create or REPLACE type dept_obj_type AS table of dept_obj;
2.定义package 和package body。
最后,执行存储过程。
/*返回pipelined table */
select deptno, dname from table(SPTest.getDept('NEW YORK')) order by deptno;
/*返回cursor*/
select SPTest.getDeptInfo(10) from dual;
/*返回具体值*/
select SPTest.getName(50) from dual;
select * from dept order by deptno;
10 ACCOUNTING NEW YORK
20 RESEARCH DALLAS
30 SALES CHICAGO
40 OPERATIONS BOSTON
为了演示方便,插入一条数据:
insert into dept(deptno, dname, loc) values(50,'SYSTEM', 'NEW YORK');
新插入的记录为:50 SYSTEM NEW YORK
我们主要演示在package中存储过程的返回类型为pipelined table,cursor 和 value三种。
1.返回类型为pipelined table。
create or REPLACE type dept_obj is OBJECT( DEPTNO NUMBER(2,0), DNAME VARCHAR2(14 BYTE) );
create or REPLACE type dept_obj_type AS table of dept_obj;
2.定义package 和package body。
create or replace package SPTest is /*return a pipelined demo start*/ type dept_data_rec_type is RECORD( DEPTNO NUMBER(2,0), DNAME VARCHAR2(14) ); type dept_ref_type is REF CURSOR; function getDept(in_loc IN VARCHAR2) return dept_obj_type pipelined; /*return a pipelined demo end*/ /*return a cursor demo start*/ FUNCTION getDeptInfo(in_deptno IN dept.deptno%TYPE) RETURN dept_ref_type; /*return a cursor demo end*/ /* return a varchar value start */ function getName(in_deptno in number) RETURN VARCHAR2; /* return a varchar value end */ end SPTest; / ----------------------------------------------------------------------------------------------- create or replace package body SPTest is /*return a pipelined demo start*/ function getDept(in_loc IN VARCHAR2) return dept_obj_type pipelined is l_dept_obj dept_obj :=dept_obj(null, null); dept_ref_type_cursor dept_ref_type; dept_data_rec dept_data_rec_type; begin open dept_ref_type_cursor for select deptno, dname from dept where loc = in_loc; loop fetch dept_ref_type_cursor into dept_data_rec; exit when dept_ref_type_cursor%NOTFOUND; l_dept_obj.DEPTNO := dept_data_rec.DEPTNO; l_dept_obj.DNAME := dept_data_rec.DNAME; pipe row(l_dept_obj); end loop; close dept_ref_type_cursor; RETURN ; end getDept; /*return a pipelined demo end*/ /*return a cursor demo start*/ FUNCTION getDeptInfo(in_deptno IN dept.deptno%TYPE) RETURN dept_ref_type AS dept_ref_type_cursor dept_ref_type; BEGIN OPEN dept_ref_type_cursor FOR SELECT deptno, dname, loc FROM dept where deptno = in_deptno; RETURN dept_ref_type_cursor; END getDeptInfo; /*return a cursor demo end*/ /* return a varchar value start */ function getName(in_deptno in number) RETURN VARCHAR2 as rtn_deptname VARCHAR2(100); begin select dname into rtn_deptname from dept where deptno = in_deptno; RETURN rtn_deptname; end getName; /* return a varchar value start */ end SPTest; /
最后,执行存储过程。
/*返回pipelined table */
select deptno, dname from table(SPTest.getDept('NEW YORK')) order by deptno;
/*返回cursor*/
select SPTest.getDeptInfo(10) from dual;
/*返回具体值*/
select SPTest.getName(50) from dual;
相关文章推荐
- Oracle中定义package以及存储过程的使用
- ORACLE语法-包(package)、存储过程(procedure)、游标(cursor)以及java对Result结果集的处理
- 如何使用plsql导出oracle数据建表语句,存储过程,视图。以及表中数据
- 如何使用plsql导出oracle数据建表语句,存储过程,视图。以及表中数据
- oracle 存储过程返回 结果集 table形式 (使用sys_refcursor 及程序包package 两种方式)
- oracle使用package来包装存储过程或function
- oracle使用package来包装存储过程或function
- 还原Wss3.0内容数据库时遇到:"ComputerName\Microsoft##SSEE 上的 WSS_Content 包含用户定义的架构。数据库在能够使用之前必须为空。请删除所有表、存储过程以及其他对象,或使用其他数据库。 " 的提示,无法加载内容数据库
- oracle 存储过程,存储函数以及定时器的综合使用
- java调用oracle 存储过程 以及游标使用
- 使用 ADO.NET 访问 Oracle 9i 存储过程
- 数据库操作_连接SQL Server数据库示例;连接ACCESS数据库;连接到 Oracle 数据库示例;SqlCommand 执行SQL命令示例;SqlDataReader 读取数据示例;使用DataAdapter填充数据到DataSet;使用DataTable存储数据库表;将数据库数据填充到 XML 文件;10 使用带输入参数的存储过程;11 使用带输入、输出参数的存储过程示;12 获得数据库中表的数目和名称;13 保存图片到SQL Server数据库示例;14 获得插入记录标识号;Exce
- Ruby之旅(二) Ruby的基本语法以及对象的使用,方法的定义及调用,属性的定义及使用
- 使用 ADO.NET 访问 Oracle 9i 存储过程(来自MSDN)
- C#中调用ORACLE的PACKAGE里方法和存储过程的应用
- 使用type类型和存储过程来完成oracle的行列转换
- 使用存储过程读取Oracle中的clob字段的数据
- javascript入门系列演示·函数的定义以及简单参数使用,调用函数
- javascript入门系列演示·函数的定义以及简单参数使用,调用函数
- 使用 ADO.NET 访问 Oracle 9i 存储过程