无法从Java调用存储过程包含Varchar2_表作为参数

无法从Java调用存储过程包含Varchar2_表作为参数,java,oracle10g,spring-jdbc,Java,Oracle10g,Spring Jdbc,我正在尝试使用SimpleJDBCall特性编写调用存储过程的java代码。 我使用的是Oracle10g,下面是需要从代码中调用的过程语法 存储过程语法: CREATE OR REPLACE PROCEDURE ImportFile( enametab IN VARCHAR2_TABLE, saltab IN DBMS NUMBER_TABLE) 存储过程正在接受Varchar2.TABLE类型和Number_表类型,这是大容量SQL类型的类型。 我尝试了以下jav

我正在尝试使用SimpleJDBCall特性编写调用存储过程的java代码。 我使用的是Oracle10g,下面是需要从代码中调用的过程语法

存储过程语法:

CREATE OR REPLACE PROCEDURE  ImportFile(
      enametab IN VARCHAR2_TABLE,
      saltab IN DBMS NUMBER_TABLE)
存储过程正在接受Varchar2.TABLE类型和Number_表类型,这是大容量SQL类型的类型。 我尝试了以下java代码来调用存储过程

Java代码

SimpleJdbcCall simpleJdbcCall = new SimpleJdbcCall(jdbcTemplate)

                .withSchemaName("<<schemaName>>")
                .withProcedureName("ImportFile")
                .declareParameters(new SqlParameter("enametab", Types.ARRAY),
                        new SqlParameter("saltab", Types.ARRAY));//

        // Creating lists

        List<String> enameList = new ArrayList<String>();
        enameList.add("one");
        enameList.add("two");

        List<Integer> salList = new ArrayList<Integer>();
        salList.add(1);
        salList.add(2);

        // Converting list into array
        String[] enameArray = enameList.toArray(new String[enameList.size()]);
        Integer[] salArray = salList.toArray(new Integer[enameList.size()]);

        MapSqlParameterSource in = new MapSqlParameterSource();
        in.addValue("enametab", enameArray);
        in.addValue("sArchiveName", salArray);

        // Executing the stored procedure
        simpleJdbcCall.execute(in);

有任何帮助/建议吗?

您需要使用
oracle.sql.ArrayDescriptor
创建一个
oracle.sql.ARRAY
来保存数据。在项目中,我们在课堂上处理这个问题。您可以自己实现此功能,也可以使用“SpringDataJDBCExtensions”项目提供的便利类。看

Caused by: java.sql.SQLException: Fail to convert to internal representation: 
    at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:112)
        at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:146)
        at oracle.sql.ARRAY.toARRAY(ARRAY.java:238)
        at oracle.jdbc.driver.OraclePreparedStatement.setObjectCritical(OraclePreparedStatement.java:9152)
        at oracle.jdbc.driver.OraclePreparedStatement.setObjectInternal(OraclePreparedStatement.java:8739)
        at oracle.jdbc.driver.OraclePreparedStatement.setObjectInternal(OraclePreparedStatement.java:9229)
        at oracle.jdbc.driver.OracleCallableStatement.setObject(OracleCallableStatement.java:4691)
        at org.springframework.jdbc.core.StatementCreatorUtils.setValue(StatementCreatorUtils.java:431)
        at org.springframework.jdbc.core.StatementCreatorUtils.setParameterValueInternal(StatementCreatorUtils.java:235)
        at org.springframework.jdbc.core.StatementCreatorUtils.setParameterValue(StatementCreatorUtils.java:150)
        at org.springframework.jdbc.core.CallableStatementCreatorFactory$CallableStatementCreatorImpl.createCallableStatement(CallableStatementCreatorFactory.java:213)
        at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:1115)
        ... 8 more