存储过程中定义参数类型为数组

存储过程

Procedure Update_Batch_Id(p_entity_id in Number,
                            p_vdr_id    In fnd_table_of_number) is
  begin

    For i In 1 .. p_vdr_id.COUNT Loop
      update cux_table_header cvs
         set cvs.attribute10 = p_entity_id
       where cvs.header_id = p_vdr_id(i);
    End Loop;
  end;

JAVA中调用

List list = new ArrayList();
...
list.add(row.getHeaderId());
...

OracleCallableStatement statement = null;
OracleConnection oracleConnection = (OracleConnection)tsn.getJdbcConnection();

int size = list.size();

if (size>0)
        {
           Number[] vdrIdArray = (Number[])list.toArray(new Number[size]);
            ARRAY vdrArray=null;
try {
                          ArrayDescriptor tableOfNumber = 
                              oracle.sql.ArrayDescriptor.createDescriptor("FND_TABLE_OF_NUMBER", 
                                                                          oracleConnection);
                         vdrArray = new ARRAY(tableOfNumber, oracleConnection, vdrIdArray);
                       String sql = 
                           "BEGIN cux_XXXXXXX_pkg.Update_Batch_Id(:1,:2);end;";
                       statement = (OracleCallableStatement)oracleConnection.prepareCall(sql);
   
                       statement.setObject(1, batchid);
                       statement.setARRAY(2, vdrArray);
                       statement.execute();
                      }catch (Exception ex) {
                               String[][] stra2 = { { "123456wewee", ex.getMessage() }, };
                               LogUtil.of(stra2, this).print(pageContext);
                            ex.printStackTrace();
                            System.out.println(ex.getMessage());
                           } 
}                      

 

转载于:https://www.cnblogs.com/huanghongbo/p/5408479.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值