java 存储过程返回列表_Oracle存储过程的返回列表如何以java来调用

以下的文章主要是向你介绍的是如何用java来调用Oracle存储过程的返回列表以为Oracle存储过程中没有返回值,它的所有返回值都通过相关参数来替代,等等操作,你如果对java来调用Oracle存储过程的返回列表的实际操作感兴趣的话,可以浏览我们的文章。

列表同样也不例外,但由于是集合,所以不能用一般的参数,必须要用pagkage了.所以要分两部分,

1, 建一个程序包。如下:

CREATE OR REPLACE PACKAGE TESTPACKAGE AS

TYPE Test_CURSOR IS REF CURSOR;

end TESTPACKAGE;

2,建立存储过程,存储过程为:

CREATE OR REPLACE PROCEDURE TESTC(p_CURSOR out TESTPACKAGE.Test_CURSOR) IS

BEGIN

OPEN p_CURSOR FOR SELECT * FROM HYQ.TESTTB;

END TESTC;

可以看到,Oracle存储是把游标(可以理解为一个指针),作为一个out 参数来返回值的。在java里调用时就用下面的代码:

package com.hyq.src;

import java.sql.*;

import java.io.OutputStream;

import java.io.Writer;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import oracle.jdbc.driver.*;

public class TestProcedureTHREE {

public TestProcedureTHREE() {

}

public static void main(String[] args ){

Stringdriver="oracle.jdbc.driver.OracleDriver";

StringstrUrl="jdbc:oracle:thin:@127.0.0.1:1521:hyq";

Statementstmt=null;

ResultSetrs=null;

Connectionconn=null;

try {

Class.forName(driver);

conn=DriverManager.getConnection(strUrl, "hyq", "hyq");

CallableStatementproc=null;

proc=conn.prepareCall("{ call hyq.testc(?) }");

proc.registerOutParameter(1,oracle.jdbc.OracleTypes.CURSOR);

proc.execute();

rs= (ResultSet)proc.getObject(1);

while(rs.next())

{

System.out.println("

" + rs.getString(1)

+ "

"+rs.getString(2)+"");

}

}

catch (SQLException ex2) {

ex2.printStackTrace();

}

catch (Exception ex2) {

ex2.printStackTrace();

}

finally{

try {

if(rs != null){

rs.close();

if(stmt!=null){

stmt.close();

}

if(conn!=null){

conn.close();

}

}

}

catch (SQLException ex1) {

}

}

}

}

在这里要注意,在执行前一定要先把oracle的驱动包放到class路径里,否则会报错的.以上就是对用java调用Oracle存储过程的返回列表相关的内容的介绍,望你会有所收获。

【编辑推荐】

【责任编辑:孙巧华 TEL:(010)68476606】

点赞 0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值