Fosdccf.blog.chinaunix.net
sdccf
全部博文(19283)
Linux酷软(214)
tmp(0)
PostgreSQL(93)
Solaris(383)
AIX(173)
SCOUNIX(575)
DB2(1005)
Shell(386)
C/C++(1187)
MySQL(1750)
Sybase(465)
Oracle(3695)
Informix(548)
HP-UX(0)
IBM AIX(2)
Sun Solaris(0)
BSD(1)
Linux(8597)
SCO UNIX(23)
2011年(1)
2009年(125)
2008年(19094)
2007年(63)
clifford
linky521
曾德标
fengzhan
leon_yu
mcuflowe
yt200902
guanyuji
GY123456
snow888
carlos94
丸喵喵
sean229
cxunix
可怜的猪
cqxc413
xzzgege
wb123456
分类: Oracle
2008-04-30 20:42:19
如何调用oracle返回游标的存储过程? Oracle Package有哪些作用呢? 简化应用设计、提高应用性能、实现信息隐藏、子程序重载。 下面是package部分代码。 create or replace package FirstPage is -- Author : MECON -- Created : 2006-7-20 上午 09:34:44 -- Purpose : 用来处理首页各个模块的显示情况 -- Public type declarations type outlist is REF CURSOR; --高中 Procedure getSeniorHighSchool( maxrow in number, minrow in number, return_list out outlist ); //可以定义其他 end FirstPage; 以上是packages的定义。 下面是package body的定义了 create or replace package body FirstPage is --高中 Procedure getSeniorHighSchool( maxrow in number, minrow in number, return_list out outlist )as begin open return_list for select * from (select a.*,rownum rnum from ( //业务语句 ) a where rownum<=maxrow) where rnum >=minrow; end; //抒写其他过程 end FirstPage; Oracle Package的基本就这写了。其余的看业务的需求了。 下面是jdbc代码的调用。 当然如果采用jdbc直接获得Connection下面的代码是没问题的。 oracle.jdbc.OracleCallableStatement cs = null; String sqlStr = "{call firstpage.getSeniorHighSchool(?,?,?)}"; ResultSet rs = null; try{ cs = (oracle.jdbc.OracleCallableStatement)conn.prepareCall(sqlStr); cs.setLong(1,arg[0]); cs.setLong(2,arg[1]); cs.registerOutParameter(3,oracle.jdbc.OracleTypes.CURSOR); cs.execute(); rs = cs.getCursor(3); while(rs.nex
t()){ //........... } rs.close(); cs.close(); }catch(Exception e){ System.out.println("produce error "); e.printStackTrace(); } 但是,如果采用连接池(比如:采用Weblogic或jboss等web服务器自带的连接池) 哈哈,这段代码就会让你头疼了。不信你试试。抛出CastClassException哈哈。 下面是另一种写法,保你没事。这种写法风水好。哈哈 CallableStatement cs = null; cs = conn.prepareCall(sql); cs.setInt(1,maxrow); cs.setInt(2,minrow); cs.registerOutParameter(3,oracle.jdbc.OracleTypes.CURSOR); cs.execute(); rs = (ResultSet)cs.getObject(3); 差别很简单。 可以看看weblogic和jboss实现连接池的代码就知道了。 一路ok了。
原文:http://canyang.blog.ccidnet.com/blog-htm-itemid-107964-do-showone-type-blog-uid-38235.html
上一篇:基础:Oracle9i PL/SQL编程的经验小结
下一篇:在oracle中限制返回结果集的大小
登录 注册