如何将自定义类型作为输入参数放在可调用语句中

时间:2012-06-07 17:07:05

标签: java oracle jdbc plsql

我需要对记录表使用可调用语句。我知道如何传递像string,int等参数。你可以写

callableStatement.setString(1, variable);
callableStatement.setInt(2, variable);

但是如何为自定义类型记录列表执行此操作?我可以考虑创建一个struct并以某种方式发送它,但我不知道该怎么做。

这是我要使用的自定义表格和程序

type transaction is record(
     trans_id   varchar2(20)
    ,issuer_name varchar2(300)
    ,location_name varchar2(300)
    ,trans_date    date
    ,issue_date      date);
  type transaction_list is table of transaction;

  procedure set_transaction
  (
    caller_id     in varchar2
   ,trans_list   in transaction_list
   ,return_code out varchar2
  );

2 个答案:

答案 0 :(得分:1)

您可以在callableStatement.setObject类型旁边使用Struct

可以在此页面的_demoInsertUsingCallableStmt方法中找到一个很好的示例:StructInsertExample

答案 1 :(得分:1)

您无法将记录定义为类型。您可以改为使用OBJECT:

CREATE OR REPLACE TYPE MY_TEST_REC AS OBJECT (
 id_ varchar2(30),
 name_ varchar2(30)
);

CREATE TABLE MY_TEST OF MY_TEST_REC;

create or replace package my_p is
  procedure proc(arg_  IN OUT MY_TEST_REC);
END;

create or replace package body my_p is
  procedure proc(arg_  IN OUT MY_TEST_REC)
  IS  
  BEGIN
    arg_.name_ := 'BAR';
  END;
END;

然后将可调用语句中的对象绑定到Struct。