【问题标题】:passing date as a parameter in stored procedure (oracle)在存储过程(oracle)中将日期作为参数传递
【发布时间】:2017-12-24 02:21:16
【问题描述】:

我正在尝试从休眠执行插入操作到 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();
        }
    }
}

现在我尝试将日期参数传递为new Date()sqldate,如上所示。和query.setParameter("P_SUBMISSIONLASTDATE", sqlDate,TemporalType.Date);but 他们都在抛出错误:-

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

【问题讨论】:

    标签: java oracle hibernate stored-procedures


    【解决方案1】:

    一种可能的解决方案是使用 java.sql.timestamp 而不是 java.sql.Date。您也可以参考SQL and PL/SQL Mappings to Oracle and JDBC Types 以验证正确的数据类型映射。

    This is an example of how get 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()));
    

    【讨论】:

      猜你喜欢
      • 2021-09-01
      • 2012-11-23
      • 2016-02-02
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2023-03-22
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多