我正在尝试使用SimpleJdbcCall功能编写用于调用存储过程的java代码。 我使用的是Oracle 10g,下面是需要从我们的代码中调用的过程语法
存储过程语法:
CREATE OR REPLACE PROCEDURE ImportFile(
enametab IN VARCHAR2_TABLE,
saltab IN DBMS NUMBER_TABLE)
存储过程正在接受Varchar2.TABLE类型和Number_TABLE类型,这是批量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);
执行上述代码后,我收到错误
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
任何帮助/建议?
答案 0 :(得分:0)
您需要使用oracle.sql.ArrayDescriptor
来创建保存数据的oracle.sql.ARRAY
。在"Spring Data JDBC Extensions"项目中,我们在SqlArrayValue
类中处理此问题。您可以自己实现此功能,也可以使用“Spring Data JDBC Extensions”项目提供的便捷类。请参阅docs。