mybatis使用 oracle自定义类型作为入参

博客主要介绍了编写MyBatis TypeHandler的相关内容,包括重写方法、导入所需的包及包的下载地址,强调若不使用这些包,字符串将无法传入数据库,还提及了调用存储过程。

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

编写mybatis typeHandler

重写方法

@Override
public void setNonNullParameter(PreparedStatement preparedStatement, int i, Object o, JdbcType jdbcType) throws SQLException {
    Connection conn = null;
    try {
        if (null != o) {
            conn = preparedStatement.getConnection();
            List<SecomLdPoInIfacePO> list = (ArrayList<SecomLdPoInIfacePO>) o;
            conn = conn.unwrap(OracleConnection.class);
            ARRAY array = getArray(conn, "SECOM_LD_PO_IN_TYPE", "SECOM_LD_PO_IN_TYPE_T", list);
            preparedStatement.setArray(i, array);
        }
    } catch (Exception e) {
        LOGGER.error("SecomLdPoInIfacePO做为数组入参异常", e);
    }
}

private ARRAY getArray(Connection con, String OracleObj, String Oraclelist, List<SecomLdPoInIfacePO> data) throws Exception {
    ARRAY array = null;
    ArrayDescriptor desc = ArrayDescriptor.createDescriptor(Oraclelist, con);
    STRUCT[] structs = new STRUCT[data.size()];
    StructDescriptor structdesc = StructDescriptor.createDescriptor(OracleObj, con);
    for (int i = 0; i < data.size(); i++) {
    //需要把字段与oracle中的自定义类型的字段一一对应
        Object[] result = {
                data.get(i).getLdId(),
                data.get(i).getSupplyName(),
                data.get(i).getInRepNo(),
                data.get(i).getWarehouseCode(),
                data.get(i).getRepType(),
                data.get(i).getSubStockName(),
                data.get(i).getCustomerGoodsInfoId(),
                data.get(i).getCustomerBrand(),
                data.get(i).getQuantity(),
                data.get(i).getOriginDateCode(),
                data.get(i).getDateCode(),
                data.get(i).getGoodsPlace(),
                data.get(i).getCustPo(),
                data.get(i).getPrice(),
                data.get(i).getNoTaxPrice(),
                data.get(i).getCurrency(),
                data.get(i).getInDate(),
                data.get(i).getDataType(),
                data.get(i).getComOrder()
        };
        structs[i] = new STRUCT(structdesc, con, result);
    }
    array = new ARRAY(desc, con, structs);
    return array;
}

导入包

oracle 11 及以上使用orai18n.jar
oracle 10及以下使用nls_charset12.jar

包下载地址

如果不使用这些包,则字符串不能传入数据库

调用存储过程

 <select id="poInIface" parameterType="java.util.Map" statementType="CALLABLE">
      {call secom_ld_edi_pkg.ins_ld_po_in(
          #{p_po_in,mode=IN,javaType=java.util.List,jdbcType=ARRAY,typeHandler=com.sekorm.edi.handlers.SecomLdPoInTypeHandler},
          #{x_flag,mode=OUT,javaType=java.lang.String,jdbcType=VARCHAR},
          #{x_msg,mode=OUT,javaType=java.lang.String,jdbcType=VARCHAR}
      )}
</select>
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值