jdbc中调用oracle 返回游标类型的存储过程

1、创建表:

     create table stud(
            sid int,
            sname varchar2(50)
     )
     并插入一条数据
     insert into stud values(1,'Tom')

2、通过包定义一个游标
 
     create or replace package pack_stud
     is
     --声明一个游标类型
            type cur is ref cursor;
     end;
3、创建存储过程

     create or replace procedure pro_select_stud(
            my_cur out pack_stud.cur
     )
     is
     begin
            open my_cur for select * from stud;
     end;

 

4、jdbc中调用


import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;

import oracle.jdbc.driver.OracleTypes;

 

public class TestProCur {


 public void test(){


  Connection con = null;
  ResultSet rs = null;
  CallableStatement cst = null;
  try{
         Class.forName("oracle.jdbc.driver.OracleDriver");
         //下面的tan是数据库名,默认是orcl,love是访问密码,默认是tiger,
         //1521是端口号,默认是1521
        con = DriverManager.getConnection
   ("jdbc:oracle:thin:@192.168.1.103:1521:tan","scott","love");
        String sql = "{call  pro_select_stud(?)}";
        cst = con.prepareCall(sql);
        cst.registerOutParameter(1, OracleTypes.CURSOR);
        cst.execute();
        rs = (ResultSet)cst.getObject(1);
        while(rs.next()){
              System.out.println(rs.getString(2));
        }
  }catch(Exception e){
   e.printStackTrace();
  }finally{


   try{
    
         if(rs !=null){
              rs.close();
         }
         if(cst != null){
              cst.close();
         }
         if(con != null){
              con.close();
         }
   }catch(Exception e){
         e.printStackTrace();
   }
   
  }
 }

 public static void main(String[] args) {
        TestProCur tpc = new TestProCur();
        tpc.test();
 }

 

 

}

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值