2013-10-06 65 views
3

我们有一个使用NamedParameterJdbcTemplate将消息保存到Oracle数据库的Spring应用程序。 sql是一个简单的插入。插入工作和数据库已更新,但无法引发以下异常。Spring JDBC:使用Oracle时出错

04:02:58.276 [org.springframework.jms.listener.DefaultMessageListenerContainer#0-1] DEBUG o.s.jdbc.core.StatementCreatorUtils - JDBC 3.0 getParameterType call not supported 
java.sql.SQLException: Unsupported feature 
    at oracle.jdbc.driver.OracleParameterMetaData.getParameterType(OracleParameterMetaData.java:166) ~[ojdbc6-11.2.0.2.0.jar:11.2.0.2.0] 
    at org.springframework.jdbc.core.StatementCreatorUtils.setNull(StatementCreatorUtils.java:231) [spring-jdbc-3.2.4.RELEASE.jar:3.2.4.RELEASE] 
    at org.springframework.jdbc.core.StatementCreatorUtils.setParameterValueInternal(StatementCreatorUtils.java:213) [spring-jdbc-3.2.4.RELEASE.jar:3.2.4.RELEASE] 
    at org.springframework.jdbc.core.StatementCreatorUtils.setParameterValue(StatementCreatorUtils.java:144) [spring-jdbc-3.2.4.RELEASE.jar:3.2.4.RELEASE] 
    at org.springframework.jdbc.core.BatchUpdateUtils.setStatementParameters(BatchUpdateUtils.java:63) [spring-jdbc-3.2.4.RELEASE.jar:3.2.4.RELEASE] 
    at org.springframework.jdbc.core.namedparam.NamedParameterBatchUpdateUtils.access$000(NamedParameterBatchUpdateUtils.java:32) [spring-jdbc-3.2.4.RELEASE.jar:3.2.4.RELEASE] 
    at org.springframework.jdbc.core.namedparam.NamedParameterBatchUpdateUtils$1.setValues(NamedParameterBatchUpdateUtils.java:47) [spring-jdbc-3.2.4.RELEASE.jar:3.2.4.RELEASE] 
    at org.springframework.jdbc.core.JdbcTemplate$4.doInPreparedStatement(JdbcTemplate.java:899) [spring-jdbc-3.2.4.RELEASE.jar:3.2.4.RELEASE] 
    at org.springframework.jdbc.core.JdbcTemplate$4.doInPreparedStatement(JdbcTemplate.java:890) [spring-jdbc-3.2.4.RELEASE.jar:3.2.4.RELEASE] 
    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:589) [spring-jdbc-3.2.4.RELEASE.jar:3.2.4.RELEASE] 
    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:617) [spring-jdbc-3.2.4.RELEASE.jar:3.2.4.RELEASE] 
    at org.springframework.jdbc.core.JdbcTemplate.batchUpdate(JdbcTemplate.java:890) [spring-jdbc-3.2.4.RELEASE.jar:3.2.4.RELEASE] 
    at org.springframework.jdbc.core.namedparam.NamedParameterBatchUpdateUtils.executeBatchUpdateWithNamedParameters(NamedParameterBatchUpdateUtils.java:40) [spring-jdbc-3.2.4.RELEASE.jar:3.2.4.RELEASE] 
    at org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate.batchUpdate(NamedParameterJdbcTemplate.java:324) [spring-jdbc-3.2.4.RELEASE.jar:3.2.4.RELEASE] 
    at org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate.batchUpdate(NamedParameterJdbcTemplate.java:319) [spring-jdbc-3.2.4.RELEASE.jar:3.2.4.RELEASE] 

我想知道是否有人可以帮助找出问题,谢谢。

+0

您willhave共享代码,只是错误也无济于事。 – Lokesh

回答

1

检查代码中的某个地方使用PreparedStatementMetaData

preparedStatement.getParameterMetaData().getParameterType(index); 这将导致此异常。

或者你将不得不分享你的代码。

7

当您在列中设置null时,setNull函数需要数据库ParameterType。 oracle驱动程序不支持ps.getParameterMetaData()。getParameterType(paramIndex) 功能,并且会引发异常并在日志中显示调试消息:“不支持JDBC 3.0 getParameterType调用”然后使用回退方法。

spring-jdbc(老版本没有这样做)的一个问题是,catch异常非常慢,并且为每个列设置一个空值,这个异常被抛出并捕获。其结果是从milleseconds查询去TOT毫秒100的...

我没有办法尚未... https://jira.springsource.org/browse/SPR-10385

https://forums.oracle.com/thread/587880

编辑:当您使用Oracle驱动程序ojdbc7.jar然后parameterMetaData .getParameterType实现

EDIT2:让我们投票支持提高;-)https://jira.springsource.org/browse/SPR-11100

更新:修复3.2.6,4.0 GA(SPR-11100)

相关问题