java - 使用 Jpa 2.1 调用存储过程时出现 "Ordinal binding and Named binding"问题

标签 java oracle hibernate stored-procedures jpa-2.1

使用:

  1. Spring Boot 1.4.0.RELEASE
  2. JPA:2.1
  3. hibernate :5.0.9
  4. hibernate 方言:org.hibernate.dialect.Oracle10gDialect
  5. Oracle 数据库:12.1.0.2
  6. 甲骨文 JDBC:ojdbc7 12.1.3-0-0

本质上,当我尝试执行存储过程时,我遇到了这个错误:

operation not allowed: Ordinal binding and Named binding cannot be combined!

完整的堆栈跟踪如下:

    2016-08-31 13:35:37.906+0200 | APP | WARN  | MvcAsync1 | o.h.e.j.s.SqlExceptionHelper | SQL Error: 17090, SQLState: 99999
2016-08-31 13:35:37.907+0200 | APP | ERROR | MvcAsync1 | o.h.e.j.s.SqlExceptionHelper | operation not allowed: Ordinal binding and Named binding cannot be combined!
2016-08-31 13:35:37.909+0200 | APP | ERROR | http-nio-8081-exec-3 | o.a.c.c.C.[.[.[.[dispatcherServlet] | Servlet.service() for servlet dispatcherServlet threw exception
java.sql.SQLException: operation not allowed: Ordinal binding and Named binding cannot be combined!
    at oracle.jdbc.driver.OracleCallableStatement.execute(OracleCallableStatement.java:5626)
    at oracle.jdbc.driver.OraclePreparedStatementWrapper.execute(OraclePreparedStatementWrapper.java:1385)
    at org.hibernate.result.internal.OutputsImpl.<init>(OutputsImpl.java:52)
    at org.hibernate.procedure.internal.ProcedureOutputsImpl.<init>(ProcedureOutputsImpl.java:32)
    at org.hibernate.procedure.internal.ProcedureCallImpl.buildOutputs(ProcedureCallImpl.java:411)
    at org.hibernate.procedure.internal.ProcedureCallImpl.getOutputs(ProcedureCallImpl.java:363)
    at org.hibernate.jpa.internal.StoredProcedureQueryImpl.outputs(StoredProcedureQueryImpl.java:234)
    at org.hibernate.jpa.internal.StoredProcedureQueryImpl.execute(StoredProcedureQueryImpl.java:217)
    at com.mycomp.services.DocumenServiceImpl.addNewDoc(DocumentServiceImpl.java:88)
    at com.mycomp.backend.rest.CreateController.lambda$0(CreateController.java:39)
    at org.springframework.web.context.request.async.WebAsyncManager$4.run(WebAsyncManager.java:316)
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at java.lang.Thread.run(Thread.java:745)

调用代码如下:

    StoredProcedureQuery sp = em.createStoredProcedureQuery("mySp")
    .registerStoredProcedureParameter("param1", Integer.class, ParameterMode.IN)                
    .registerStoredProcedureParameter("outParam", Integer.class, ParameterMode.OUT)
    .setParameter("param1", request.getTransactiontypeId());
    sp.execute();

打开 SQL 调试输出,它显示生成的 sql 调用为 {call mySp(?,?)} .

这似乎...狡猾(因为它不包含指定名称的提示),但我知道它可能只是在 hibernate 状态下进行内部翻译?

如果我将存储过程设置更改为使用位置参数,实际上一切正常,但我真的更喜欢使用命名参数。

存储过程规范:

PROCEDURE mySp (param1 IN tdocs.transactiontype_id%TYPE,<br/> outParam OUT tdocs.doc_id%TYPE );

最佳答案

这似乎是 Hibernate 5.0.9 中的错误。对我来说,切换到 Hibernate 5.0.11.Final 就成功了,没有其他变化。

感谢 Mihai Cicu 在评论中指出了这个方向。

关于java - 使用 Jpa 2.1 调用存储过程时出现 "Ordinal binding and Named binding"问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39249318/

相关文章:

c# - 工作中断查询之谜

sql - 当我有选择关键字时出现缺少选择关键字错误

mysql - CSV 导入数据库,在运行时改变外键属性

java - Spring JtaTransactionManager 和 HibernateTransactionManager 的区别

java - JVMTI 类未准备好

java.util.Scanner : Behavior with whitespace-only input?

c# - 将 oracle 查询的嵌套选择转换为 linq

java - hibernate .jpa.criteria.BasicPathUsageException : Cannot join to attribute of basic type

java - 亚像素图形运动

java - 更新 Gradle 引用以包含 Maven 本地 jar(libGDX 和 Tween 引擎)