1、nest表组合成结果集,然后以游标变量的形式返回

--创建类型

create or replace package mytest is

-- Author  : ADMINISTRATOR
  -- Created : 2008-5-13 11:19:28
  -- Purpose : test
 
TYPE record_type IS RECORD(
      code   VARCHAR2(18),
      p_name VARCHAR2(16));

TYPE ref_cur_type IS REF CURSOR;
end mytest;

CREATE OR REPLACE TYPE table_type IS TABLE OF record_type;

--创建过程

CREATE OR REPLACE PROCEDURE testproc( v_ref_cur out mytest.ref_cur_type) IS

v_record record_type;

v_table table_type := table_type();

BEGIN
   FOR i IN 1 .. 9 LOOP
      v_record := NEW record_type('45212319830810435' || i, '侯廷文' || i);
      v_table.EXTEND;
      v_table(i) := v_record;
   END LOOP;

OPEN v_ref_cur FOR
      SELECT * FROM TABLE(CAST(v_table AS table_type));

END testproc;

--java代码:

OracleCallableStatement cstmt = (OracleCallableStatement) con
                .prepareCall(&{call testproc(?)}&);
        cstmt.registerOutParameter(1, OracleTypes.CURSOR);
        cstmt.execute();
        ResultSet rs = (ResultSet) cstmt.getObject(1);
        while (rs.next()) ...{
            System.out.print(rs.getString(1) + & &);
            System.out.print(rs.getString(2) + & &);
            System.out.println();
        }

2、PL/SQL varray数组类型的形式返回结果

--创建类型
CREATE OR REPLACE TYPE myarr IS VARRAY(200) OF VARCHAR2(256);

--创建过程

CREATE OR REPLACE PROCEDURE testvarray(thearr OUT myarr) IS

BEGIN
   thearr := myarr();
   FOR i IN 1 .. 100 LOOP
      thearr.EXTEND;
      thearr(i) := '我是侯廷文'||i;
   END LOOP;
END testvarray;

--java代码:

OracleCallableStatement cstmt = (OracleCallableStatement) con.prepareCall(&{call testvarray(?)}&);
        cstmt.registerOutParameter(1, OracleTypes.ARRAY, &MYARR&);

    cstmt.execute();
        ARRAY array = cstmt.getARRAY(1);
        Datum[] datas = array.getOracleArray();

for (int i = 0; i < datas.length; i++) ...{
            System.out.println(i + &:& + new String(datas[i].getBytes()));
        }

3、PL/SQL 的Object类型返回,对应jdbc的Struct

--创建类型

CREATE OR REPLACE TYPE record_type as object(code VARCHAR2(18),
                                             p_name VARCHAR2(16));

--创建过程

create or replace procedure testStruct(theObj OUT record_type) is
begin
  theObj:=record_type('452134198308104351','侯廷文');
end testStruct;

--java代码:

OracleCallableStatement cstmt = (OracleCallableStatement) con
                .prepareCall(&{call testStruct(?)}&);
        cstmt.registerOutParameter(1, OracleTypes.STRUCT, &RECORD_TYPE&);
        cstmt.execute();
        STRUCT struct = cstmt.getSTRUCT(1);
        Datum[] datas = struct.getOracleAttributes();
      for (int i = 0; i < datas.length; i++) ...{
            System.out.print(i + &:& + new String(datas[i].shareBytes()));
            System.out.println();
        }

4、PL/SQL 的table类型返回,对应jdbc的ARRAY

--创建类型

create or replace type nest_table_type IS TABLE OF VARCHAR2(200);

--创建过程

CREATE OR REPLACE PROCEDURE testtable(thetable OUT nest_table_type) IS
BEGIN
   thetable := nest_table_type();
   FOR i IN 1 .. 100 LOOP
      thetable.EXTEND;
      thetable(i) := dbms_random.STRING('X', 3) || '侯廷文' || i;
   END LOOP;
END testtable;

--java代码:

OracleCallableStatement cstmt = (OracleCallableStatement) con
         .prepareCall(&{call testtable(?)}&);
         cstmt.registerOutParameter(1, OracleTypes.ARRAY, &NEST_TABLE_TYPE&);
         cstmt.execute();
         ARRAY array = cstmt.getARRAY(1);
         Datum[] datas=array.getOracleArray();
         for (int i = 0; i < datas.length; i++) ...{
         System.out.print(i + &:& + new String(datas[i].shareBytes()));
         System.out.println();
         }

5、PL/SQL 的Index table类型,注意该类型只能在
   oci8方式连接下使用,所需要的动态连接库文件(ocijdbc9.dll)要在环境变量里进行设置
   (例如:path=D:oracleora90BIN),在不同的环境下OCI驱动还可能出现类装载异常,
   所以返回索引表尽管方便,但偶尔会出现意想不到的错误

--创建类型

CREATE OR REPLACE PACKAGE p_type IS
TYPE index_table_type IS TABLE OF VARCHAR2(256) INDEX BY BINARY_INTEGER;
END;

--创建过程

create or replace procedure testIndexTable(v_iTable OUT p_type.index_table_type) is
begin
  FOR i IN 1 .. 100 LOOP
  v_iTable(i):=dbms_random.string('X',5)||'侯廷文'||i;END LOOP;
end testIndexTable;

--java代码:

OracleCallableStatement cstmt = (OracleCallableStatement) con
                .prepareCall(&{call testindextable(?)}&);
        cstmt.registerIndexTableOutParameter(1, 200, OracleTypes.VARCHAR, 256);
        cstmt.execute();
        String[] strs = (String[]) cstmt.getPlsqlIndexTable(1);
        for (int i = 0; i < strs.length; i++) ...{
            System.out.println(i + &:& + strs[i]);
        }

6、nestTable里装的是Person Object

--创建类型

CREATE OR REPLACE TYPE Person AS OBJECT
(
       p_code VARCHAR2(32),
       p_name VARCHAR2(16),
       p_age NUMBER,
       p_birthday DATE
);

CREATE OR REPLACE TYPE person_table_type IS TABLE OF Person;

--创建过程

CREATE OR REPLACE PROCEDURE testtableofobject(v_table OUT person_table_type) IS
BEGIN
   v_table := person_table_type();
   FOR i IN 1 .. 5 LOOP
      v_table.EXTEND;
      v_table(i) := NEW person('45212319880810435' || i,
                               '侯廷文' || i,
                               20 + i,
                               to_date('1985-08-1' || i, 'YYYY-MM-DD'));
   END LOOP;
END testtableofobject;

--java代码:

OracleCallableStatement cstmt = (OracleCallableStatement) con
                .prepareCall(&{call testtableofobject(?)}&);
       cstmt.registerOutParameter(1, OracleTypes.ARRAY, &person_table_type&
                .toUpperCase());
        cstmt.execute();
        ARRAY array = cstmt.getARRAY(1);
        Datum[] datas = array.getOracleArray();
        for (int i = 0; i < datas.length; i++) ...{
            System.out.print(i + &: &);
            Datum[] personAttributes = ((STRUCT) datas[i])
                    .getOracleAttributes();
            System.out.print(&p_code:&
                    + new String(personAttributes[0].getBytes()) + & &);
            System.out.print(&p_name:&
                    + new String(personAttributes[1].getBytes()) + & &);
            System.out.print(&p_age:& + personAttributes[2].intValue() + & &);
            System.out.print(&p_birthday:& + personAttributes[3].dateValue()
                    + & &);
            System.out.println();
        }

7、输入参数为nestTable里装的是Person Object
   注意要将nls_charset12.jar放入ClassPath中,否则报SQLException:
   Non supported character set: oracle-character-set-852

--创建类型

CREATE OR REPLACE TYPE Person AS OBJECT
(
       p_code VARCHAR2(32),
       p_name VARCHAR2(16),
       p_age NUMBER,p_birthday DATE
);

CREATE OR REPLACE TYPE person_table_type IS TABLE OF Person;

CREATE TABLE personTable OF person;

--创建过程

CREATE OR REPLACE PROCEDURE testInPersons(persons IN person_table_type) IS
BEGIN
FORALL i IN persons.first .. persons.count
INSERT INTO personTable VALUES(persons(i));
COMMIT;
END testInPersons;

--java代码:

OracleCallableStatement cstmt = (OracleCallableStatement) con
                .prepareCall(&{call testInPersons(?)}&);
        StructDescriptor sd = new StructDescriptor(&PERSON&, con);
        Object[] personAttrs1 = new Object[] ...{ &This is code11&, &侯廷文11&,
                new NUMBER(32), new Date(new java.util.Date().getTime()) };
        STRUCT person1 = new STRUCT(sd, con, personAttrs1);

Object[] personAttrs2 = new Object[] ...{ &This is code22&, &侯廷文22&,
                new NUMBER(33), new Date(new java.util.Date().getTime()) };
        STRUCT person2 = new STRUCT(sd, con, personAttrs2);

ArrayDescriptor ad = new ArrayDescriptor(&person_table_type&
                .toUpperCase(), con);
        ARRAY persons = new ARRAY(ad, con, new STRUCT[] ...{ person1, person2 });
        cstmt.setARRAY(1, persons);
        cstmt.execute();
    }

Oracle存储过程java 调用的更多相关文章

  1. oracle存储过程递归调用

    oracle存储过程递归调用,如果where子句使用的是传入的参数, 在以后的递归调用中参数就是第一次调用的参数值,解决办法是定义变量,使用自定义的变量问题可以解决.

  2. mysql 触发器 存储过程 java调用

    触发器和存储过程是为了提高SQL的运行效率. SQL语句先编译.后执行,而触发器与存储过程都会提前预编译完成,且只编译一次,供反复调用. 随着时代的进步,硬件与带宽的提升,触发器和存储过程提升效率并不 ...

  3. Oracle存储过程的调用(返回参数)

    CREATE OR REPLACE PROCEDURE test_in_out_exception (v_empno VARCHAR2,v_guess_sal NUMBER,v_true_sal OU ...

  4. oracle存储过程jdbc调用

    package com.jckb.procedure; import java.sql.CallableStatement; import java.sql.Connection; import ja ...

  5. oracle 存储过程中调用存储过程

    create procedure sp_name() begin ……… end 比如: create procedure pro_showdbs() show datebase; end //用ex ...

  6. Oracle存储过程的调用和执行

    1.什么是存储过程: 用于在数据库中完成特定的操作或者任务.是一个PLSQL程序块,可以永久的保存在数据库中以供其他程序调用. 2.无参存储过程的使用: Normal 0 7.8 磅 0 2 fals ...

  7. Oracle存储过程中调用DBLink同义词出现错误:PLS-00201: 必须声明标识符

    前几天编写一个存储过程,需要访问远程数据库的字段,于是建立一个dbLink并建了同义词: CREATE PUBLIC DATABASE LINK orcl@dbc CONNECT TO orcl ID ...

  8. Oracle存储过程创建及调用(转)

    在大型数据库系统中,有两个很重要作用的功能,那就是存储过程和触发器.在数据库系统中无论是存储过程还是触发器,都是通过SQL 语句和控制流程语句的集合来完成的.相对来说,数据库系统中的触发器也是一种存储 ...

  9. jdbc调用 oracle 存储过程操作

    创建有参存储函数findEmpNameAndSal(编号),查询7902号员工的的姓名和月薪,[返回多个值,演示out的用法]当返回2个或多个值,必须使用out符号当返回1个值,就无需out符号 cr ...

随机推荐

  1. 电赛菜鸟营培训(一)——STM32F103CB之LED控制

    一.STM32F103C8 引脚分布 二.LED的共阴.共阳接法 这里应该是七段数码管的接法. 限流电阻选择为470,在Multism中仿真,也需要接入,否则会出现闪烁情况.或者直接更改属性. 三.消 ...

  2. Centos6.4编译安装Node.js(已验证)

    1.准备源文件包 [felix@MyTerminal Downloads]$ mv node-6.5.0 node [felix@MyTerminal Downloads]$ ls node node ...

  3. javascript正则表达式速查

    声明:本文为原创文章,如需转载,请注明来源并保留原文链接前端小尚,谢谢! 作用 数据有效性验证 替换文本 提取文本 声明方式 字面量的声明方式 示例:var re = /a/gi; RegExp声明方 ...

  4. Knowledgeroot安装与使用入门

    采用 PHP 开发的知识库系统,基于树状结构对内容进行组织.使用 FCKEditor 进行内容编辑. 效果http://demo.knowledgeroot.org/index.php?id=2230 ...

  5. VMware Tools安装

    不是每一个程序员都必须玩过linux,只是博主觉得现在的很多服务器都是linux系统的,而自己属于那种前端也搞,后台也搞,对框架搭建也感兴趣,但是很多生产上的框架和工具都是安装在服务器上的,而且有不少 ...

  6. mvc-4控制器和状态(1)

    导语 将状态保存在客户端可以加快页面反映:但应当避免状态或数据保存在DOM中:在MVC中,状态应该保存在控制器中 控制器是视图和模型的纽带,只有控制器知道视图和模型的存在并将它们连接在一起:当加载页面 ...

  7. 判断 Gym 100502K Train Passengers

    题目传送门 /* 题意:几个判断,车上的人不能 <0 或 > C:车上初始和结束都不能有人在 (为0):车上满员时才有等候的人 水题:难点在于读懂题目意思,状态不佳,一直没搞懂意思,在这题 ...

  8. 【LINUX/UNIX网络编程】之使用消息队列,信号量和命名管道实现的多进程服务器(多人群聊系统)

    RT,使用消息队列,信号量和命名管道实现的多人群聊系统. 本学期Linux.unix网络编程的第三个作业. 先上实验要求: 实验三  多进程服务器 [实验目的] 1.熟练掌握进程的创建与终止方法: 2 ...

  9. 关于 List<T>

    System.Object   System.Collections.Generic.List<T>   list<string,string>,这种形式本身就是错误的,你可以 ...

  10. WebRTC手记之本地视频采集

    转载请注明出处:http://www.cnblogs.com/fangkm/p/4374610.html 前面两篇文章介绍WebRTC的运行流程和使用框架接口,接下来就开始分析本地音视频的采集流程.由 ...