Antoine DESSAIGNE created CAMEL-10870:
-----------------------------------------

             Summary: camel-sql stored procedures don't support negative 
vendor-specific JDBC types
                 Key: CAMEL-10870
                 URL: https://issues.apache.org/jira/browse/CAMEL-10870
             Project: Camel
          Issue Type: Bug
          Components: camel-sql
            Reporter: Antoine DESSAIGNE


When you use a vendor-specific JDBC type in {{camel-sql}} you need to use its 
value instead of its label.

For instance, if you use oracle if you want to call a stored procedure that 
returns a {{FIXED_CHAR}} type you need to write:
{noformat}
<to uri="sql-stored:PROCEDURE1(OUT 999 result)?dataSource=oracle"/>
{noformat}
All values are defined here: 
https://docs.oracle.com/cd/E16338_01/appdev.112/e13995/constant-values.html#oracle_jdbc_OracleTypes_ARRAY

You can notice that there are negative values in this list ({{CURSOR}} for 
instance). Unfortunately the negative values aren't handled by the parser which 
leads to the following exception
{noformat}
org.apache.camel.component.sql.stored.template.ast.ParseRuntimeException: Field 
-10 not found from java.procedureName.Types
        at 
org.apache.camel.component.sql.stored.template.ast.ParseHelper.parseSqlType(ParseHelper.java:41)
        at 
org.apache.camel.component.sql.stored.template.generated.SSPTParser.OutParameter(SSPTParser.java:92)
        at 
org.apache.camel.component.sql.stored.template.generated.SSPTParser.Parameter(SSPTParser.java:60)
        at 
org.apache.camel.component.sql.stored.template.generated.SSPTParser.parse(SSPTParser.java:23)
        at 
org.apache.camel.component.sql.stored.template.TemplateParser.parseTemplate(TemplateParser.java:31)
        at 
org.apache.camel.component.sql.stored.CallableStatementWrapperFactory.getTemplateStoredProcedure(CallableStatementWrapperFactory.java:71)
        at 
org.apache.camel.component.sql.stored.CallableStatementWrapper.populateStatement(CallableStatementWrapper.java:104)
        at 
org.apache.camel.component.sql.stored.SqlStoredProducer$1.execute(SqlStoredProducer.java:69)
        at 
org.apache.camel.component.sql.stored.CallableStatementWrapper.call(CallableStatementWrapper.java:55)
        at 
org.apache.camel.component.sql.stored.SqlStoredProducer.process(SqlStoredProducer.java:43)
{noformat}




--
This message was sent by Atlassian JIRA
(v6.3.15#6346)

Reply via email to