【问题标题】:camel sql-stored ends in "java.sql.SQLException: Non supported SQL92 token at position" with Oracle datasource骆驼 sql-stored 以 Oracle 数据源的“java.sql.SQLException: Non supported SQL92 token at position”结尾
【发布时间】:2020-05-09 15:12:43
【问题描述】:

当我使用存储过程运行以下简单路由时,会导致异常:“java.sql.SQLException: Non supported SQL92 token at position”

具有嵌入式 Derby 数据源的相同路由按预期工作。

问题

有什么想法吗?我的“实现”有问题还是底层 jar 文件有问题?

堆栈:

  • 骆驼2.23.2
  • ojdbc7.jar
  • Spring XML

路线:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xmlns:jdbc="http://www.springframework.org/schema/jdbc" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc.xsd
       http://camel.apache.org/schema/spring http://camel.apache.org/schema/spring/camel-spring.xsd">

    <!-- In Memory Database
  <jdbc:embedded-database id="myDataSource" type="DERBY">
    <jdbc:script location="classpath:/sql/createAndPopulateDatabase.sql"/>
  </jdbc:embedded-database>
  -->

    <bean id="oracleDataSource" class="org.apache.commons.dbcp2.BasicDataSource">
        <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"/>
        <property name="url" value="jdbc:oracle:thin:@..."/>
        <property name="username" value="xx"/>
        <property name="password" value="yy"/>
    </bean>

    <bean id="sql-stored" class="org.apache.camel.component.sql.SqlComponent">
        <property name="dataSource" ref="oracleDataSource"/>
    </bean>

    <camelContext id="camel" 
        xmlns="http://camel.apache.org/schema/spring">
        <route>
            <from uri="direct:start"/>
            <setHeader headerName="in1">
                <constant>1</constant>
            </setHeader>
            <setHeader headerName="in2">
                <constant>1</constant>
            </setHeader>
            <to uri="sql-stored:INOUTDEMO(INTEGER ${headers.in1},INOUT INTEGER ${headers.in2} out1,OUT INTEGER out2)"/>
            <log message="Result: ${body}" loggingLevel="INFO" />
        </route>
    </camelContext>
</beans>

存储过程: 我知道该过程在 oracle db 中不起作用,但在相关类/方法识别到该过程不工作/甚至不存在之前“很长时间”抛出异常。

CREATE PROCEDURE INOUTDEMO(IN1 INTEGER, INOUT IN2 INTEGER, OUT OUT1 INTEGER)
 PARAMETER STYLE JAVA
 LANGUAGE JAVA
 EXTERNAL NAME
'org.apache.camel.component.sql.stored.TestStoredProcedure.inoutdemo';

堆栈跟踪:

Caused by: org.springframework.jdbc.UncategorizedSQLException: PreparedStatementCallback; uncategorized SQLException; SQL state [99999]; error code [17034]; Nicht unterstütztes SQL92-Token in Position: 20; nested exception is java.sql.SQLException: Nicht unterstütztes SQL92-Token in Position: 20
    at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:89)
    at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:81)
    at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:81)
    at org.springframework.jdbc.core.JdbcTemplate.translateException(JdbcTemplate.java:1414)
    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:632)
    at org.apache.camel.component.sql.SqlProducer.process(SqlProducer.java:116)
    at org.apache.camel.util.AsyncProcessorConverterHelper$ProcessorToAsyncProcessorBridge.process(AsyncProcessorConverterHelper.java:61)
    at org.apache.camel.processor.SendProcessor.process(SendProcessor.java:148)
    at org.apache.camel.processor.RedeliveryErrorHandler.process(RedeliveryErrorHandler.java:548)
    at org.apache.camel.processor.CamelInternalProcessor.process(CamelInternalProcessor.java:201)
    at org.apache.camel.processor.Pipeline.process(Pipeline.java:138)
    at org.apache.camel.processor.Pipeline.process(Pipeline.java:101)
    at org.apache.camel.processor.CamelInternalProcessor.process(CamelInternalProcessor.java:201)
    at org.apache.camel.component.direct.DirectProducer.process(DirectProducer.java:76)
    at org.apache.camel.processor.SharedCamelInternalProcessor.process(SharedCamelInternalProcessor.java:186)
    at org.apache.camel.processor.SharedCamelInternalProcessor.process(SharedCamelInternalProcessor.java:86)
    at org.apache.camel.impl.ProducerCache$1.doInProducer(ProducerCache.java:541)
    at org.apache.camel.impl.ProducerCache$1.doInProducer(ProducerCache.java:506)
    at org.apache.camel.impl.ProducerCache.doInProducer(ProducerCache.java:369)
    at org.apache.camel.impl.ProducerCache.sendExchange(ProducerCache.java:506)
    at org.apache.camel.impl.ProducerCache.send(ProducerCache.java:229)
    at org.apache.camel.impl.DefaultProducerTemplate.send(DefaultProducerTemplate.java:144)
    at org.apache.camel.impl.DefaultProducerTemplate.sendBody(DefaultProducerTemplate.java:161)
    ... 30 more

Caused by: java.sql.SQLException: Nicht unterstütztes SQL92-Token in Position: 20
    at oracle.jdbc.driver.OracleSql.handleODBC(OracleSql.java:1306)
    at oracle.jdbc.driver.OracleSql.parse(OracleSql.java:1192)
    at oracle.jdbc.driver.OracleSql.getSql(OracleSql.java:326)
    at oracle.jdbc.driver.OracleParameterMetaData.getParameterMetaData(OracleParameterMetaData.java:46)
    at oracle.jdbc.driver.OraclePreparedStatement.getParameterMetaData(OraclePreparedStatement.java:11621)
    at oracle.jdbc.driver.OraclePreparedStatementWrapper.getParameterMetaData(OraclePreparedStatementWrapper.java:1552)
    at org.apache.commons.dbcp2.DelegatingPreparedStatement.getParameterMetaData(DelegatingPreparedStatement.java:162)
    at org.apache.commons.dbcp2.DelegatingPreparedStatement.getParameterMetaData(DelegatingPreparedStatement.java:162)
    at org.apache.camel.component.sql.SqlProducer$2.doInPreparedStatement(SqlProducer.java:120)
    at org.apache.camel.component.sql.SqlProducer$2.doInPreparedStatement(SqlProducer.java:1)
    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:617)
    ... 48 more

【问题讨论】:

    标签: oracle apache-camel camel-sql


    【解决方案1】:

    对于 oracle 过程/函数参数,它应该是变量名,后跟输入/输出,后跟数据类型。 例如“out1 out integer”

    【讨论】:

    • 感谢四位您的启发。
    【解决方案2】:

    我让它“工作”的唯一方法是这样的:

    <to uri="sql-stored: CALL HELLOWORLD(:#testValue,:#result)"/-->
    

    这样 - 没有 IN、INOUT、OUT 或类型参数和“CALL” - 至少可以在 oracle db 中执行存储过程。

    不幸的是,我仍在努力将存储过程的返回值映射回驼峰标头或主体变量。

    【讨论】:

      猜你喜欢
      • 2022-01-22
      • 1970-01-01
      • 2016-11-03
      • 2019-11-17
      • 2019-09-20
      • 2020-10-23
      • 1970-01-01
      • 2012-05-05
      • 2020-01-04
      相关资源
      最近更新 更多