当前位置: 首页 > 知识库问答 >
问题:

在存储过程中作为参数传递日期(oracle)

叶坚
2023-03-14

我正在尝试执行从hibernate到oracle表的插入操作。我的存储过程是:-

create or replace PROCEDURE          ADMSN_TABLE (
  P_ID                            NUMBER,
  P_ADMISSIONFOR                  VARCHAR2,
  P_SUBMISSIONDATE                DATE,                            --NOT NULL
  P_SUBMISSIONLASTDATE            DATE                          --NOT NULL

)
IS
  v_sno number;

  BEGIN
      INSERT INTO ORACLE.ADMISSION(AMSNID,ADMISSIONFOR,SUBMISSIONDATE,
 SUBMISSIONLASTDATE)
      VALUES (P_ID,P_ADMISSIONFOR,P_SUBMISSIONDATE,P_SUBMISSIONLASTDATE);

      COMMIT;
  END;
    public void callProc(){

        Date utilDate= new Date();
        java.sql.Date sqlDate = new java.sql.Date(utilDate.getTime());
        System.out.println(sqlDate);


        Date date = new Date();
        SimpleDateFormat smd = new SimpleDateFormat("dd-MMM-YYYY");
        String sdate = smd.format(date);
        System.out.println(sdate);

    try {
    session = sessionFactory.openSession();
    transaction = session.beginTransaction();
    StoredProcedureQuery query = session.createStoredProcedureQuery("ADMSN_TABLE");
query.registerStoredProcedureParameter("P_ID", Number.class, 
ParameterMode.IN);
query.registerStoredProcedureParameter("P_ADMISSIONFOR", String.class, 
ParameterMode.IN);
query.registerStoredProcedureParameter("P_SUBMISSIONDATE", Date.class, 
ParameterMode.IN);             
query.registerStoredProcedureParameter("P_SUBMISSIONLASTDATE",Date.class, 
ParameterMode.IN);

            query.setParameter("P_ID", 1);
            query.setParameter("P_ADMISSIONFOR", "schoolfee");
            query.setParameter("P_SUBMISSIONDATE", sqlDate);
            query.setParameter("P_SUBMISSIONLASTDATE", sqlDate);
            query.execute();
            System.out.println("excuted");
        }catch(Exception ex){
            ex.printStackTrace();
        }
    }
}
Caused by: org.hibernate.exception.SQLGrammarException: 
Error calling CallableStatement.getMoreResults at 
org.hibernate.exception.internal.SQLStateConversionDelegate.convert
(SQLStateConversionDelegate.java:106) at 
org.hibernate.exception.internal.StandardSQLExceptionConverter.convert
(StandardSQLExceptionConverter.java:42) at 
org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert
(SqlExceptionHelper.java:111)
at org.hibernate.result.internal.OutputsImpl.convert
at org.hibernate.result.internal.OutputsImpl.<init>
(OutputsImpl.java:55)
at org.hibernate.procedure.internal.ProcedureOutputsImpl.<init>
(ProcedureOutputsImpl.java:32)
at org.hibernate.procedure.internal.ProcedureCallImpl.buildOutputs
(ProcedureCallImpl.java:453)
at org.hibernate.procedure.internal.ProcedureCallImpl.getOutputs
(ProcedureCallImpl.java:404)
    at org .hibernate.procedure.internal.ProcedureCallImpl.outputs
(ProcedureCallImpl.java:663)
    at org.hibernate.procedure.internal.ProcedureCallImpl.execute
(ProcedureCallImpl.java:646)
    ... 41 more
Caused by: java.sql.SQLException: ORA-06550: line 1, column 7:
PLS-00306: wrong number or types of arguments in call to 'ADMSN_TABLE'
ORA-06550: line 1, column 7:
PL/SQL: Statement ignored

共有1个答案

岳茂
2023-03-14

一个可能的解决方案是使用java.sql.timestamp而不是java.sql.date。另外,您可以将SQL和PL/SQL映射引用到Oracle和JDBC类型,以验证数据类型映射是否正确。

这是一个如何获取java.sql.timestamp的示例

java.util.Date utilDate = new java.util.Date();
Calendar cal = Calendar.getInstance();
cal.setTime(utilDate);
cal.set(Calendar.MILLISECOND, 0);
System.out.println(new java.sql.Timestamp(utilDate.getTime()));
System.out.println(new java.sql.Timestamp(cal.getTimeInMillis()));
 类似资料:
  • 问题内容: 我有大约六种通用但相当复杂的存储过程和函数,我想以一种更通用的方式使用它们。 理想情况下,我希望能够将表名作为参数传递给过程,因为当前它是硬编码的。 我所做的研究表明,我需要将过程中所有现有的SQL转换为使用动态SQL,以便从参数中拼接动态表名称,但是我想知道是否还有一种更简便的方法可以通过另一种方式引用该表? 例如: 如果是这样,如何从表名设置@MyTable变量? 我正在使用SQL

  • 问题内容: 我正在创建一些存储过程来管理我的数据库。特别是,我想创建一个存储过程来编辑特定行的一列,但是我想通过将列名作为参数传递来做到这一点。 那就是我想做的 使用该参数,我找到了要编辑的特定行,并且我想使用该参数来仅编辑我想要的列。 正如我在其他主题上所读到的那样,我已经尝试使用或定义局部变量,但没有找到解决方案。 有什么帮助吗? 问题答案: 您将需要使用 动态SQL : 请注意,正如Paul

  • 我试图通过Oracle光标从python到Oracle存储过程(SP)。要求SP获取数据并将数据插入表中。SP取两个参数p1和p2 p1 以下是存储过程的详细信息: p2sys_refcursor,数据将以串联格式(col1|col2|...) 获取cur.callproc(“LIBRA.pt1,[linestr,result]”行中的“DatabaseError:ORA-01036:非法变量名称

  • 问题内容: 我有一个带有以下参数的T-SQL存储过程 我想知道是否可以通过as参数传递结果: 我尝试了类似的方法,但是它不起作用。 问题答案: 您在示例中编写的SELECT查询可能会带回多行(您的SELECT不具有WHERE子句或TOP(n))。如果您打算让过程使用一组“表格”参数,那么从SQL Server 2008开始,您可以使用表值参数。 这涉及到创建用户定义的表表,这无疑将意味着调整存储过

  • 问题内容: 例如,这不起作用: 产生: 但是,这按预期工作: 在select语句中使用参数作为表名需要什么语法?这有可能吗? 问题答案: 准备好的语句是您所需要的。

  • 问题内容: 我正在使用一个存储过程,在其中发送数据库中其类型为的存储过程,并且还声明parameter 。 当我将列名传递为float时,它给出了错误: 消息8114,将数据类型nvarchar转换为float时出错。 这是我的测试查询 当我将参数类型更改为时,它给了我这个错误: 消息8117,操作数数据类型varchar对avg运算符无效。 我该如何解决? 更新 : 这是我的存储过程: 问题答案