oracle存储过程返回游标 java_Java jdbc调用oracle存储过程返回游标例子

本文介绍了如何在Oracle中创建一个返回游标的存储过程,并通过Java JDBC进行调用。首先创建了一个名为users的测试表,然后定义了一个名为pkg_test的包,包含一个get方法,该方法打开一个游标并返回用户数据。在Java代码中,通过CallableStatement注册输出参数并执行存储过程,最后遍历并打印ResultSet中的用户信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.创建测试表

create table users(

userid int primary key,

username varchar2(20),

userpwd  varchar2(20)

);

insert into users values(1,'test','test');

insert into users values(2,'test','test');

insert into users values(3,'test','test');

insert into users values(4,'test','test');

insert into users values(5,'test','test');

insert into users values(6,'test','test');

insert into users values(7,'test','test');

2.创建存储过程

创建包

create or replace package pkg_test

as

type cursor0 is ref cursor;

procedure get(p_id int,p_rc out cursor0);

end pkg_test;

创建包的内容

create or replace package body pkg_test as

procedure get(p_id int, p_rc out cursor0) is

begin

dbms_output.put_line(p_id);

open p_rc for

select userid, username, userpwd from users;

end get;

end pkg_test;

3.java调用

package com.wei;

import java.sql.CallableStatement;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.ResultSet;

import java.sql.SQLException;

/***

*

* 测试 jdbc 连接 oracle 存储过程 返回游标

*

* @author wei

*

*/

public class Main {

public static void main(String[] args) {

try {

DriverManager.registerDriver(new oracle.jdbc.OracleDriver());

Class.forName("oracle.jdbc.driver.OracleDriver");

String url = "jdbc:oracle:thin:@127.0.0.1:1521:wei";

String username = "test";

String password = "admin";

Connection conn = DriverManager.getConnection(url, username,

password);

String sql = "{call pkg_test.get(?,?)}";

CallableStatement cstmt = conn.prepareCall(sql);

cstmt.setInt(1, 1);

cstmt.registerOutParameter(2, oracle.jdbc.OracleTypes.CURSOR);

cstmt.execute();

ResultSet rs = (ResultSet) cstmt.getObject(2);

while (rs.next()) {

System.out.println(rs.getInt(1) + "/t" + rs.getString(2) + "/t"

+ rs.getString(3));

}

} catch (SQLException e) {

e.printStackTrace();

} catch (ClassNotFoundException e) {

e.printStackTrace();

}

}

}

输出结果:

1 test test

2 test test

3 test test

4 test test

5 test test

6 test test

7 test test

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值