简体   繁体   English

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

[英]passing date as a parameter in stored procedure (oracle)

i am trying to perform insert operation from hibernate into the oracle table.我正在尝试从休眠执行插入操作到 oracle 表中。 my stored procedure is:-我的存储过程是:-

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;

the way i am calling this procedure from hibernate:-我从休眠中调用此过程的方式:-

    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();
        }
    }
}

now i tried to pass date parameter as new Date() or sqldate like given above.现在我尝试像上面给出的那样将日期参数作为new Date()sqldate and query.setParameter("P_SUBMISSIONLASTDATE", sqlDate,TemporalType.Date);query.setParameter("P_SUBMISSIONLASTDATE", sqlDate,TemporalType.Date); but all of them are throwing error:-但他们都在抛出错误: -

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

One possible solution is to use a java.sql.timestamp instead of java.sql.Date.一种可能的解决方案是使用 java.sql.timestamp 而不是 java.sql.Date。 Also you can refer to SQL and PL/SQL Mappings to Oracle and JDBC Types in order to verify the correct data type mapping.您还可以参考SQL 和 PL/SQL 映射到 Oracle 和 JDBC 类型以验证正确的数据类型映射。

This is an example of how get java.sql.timestamp 这是如何获取 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()));

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM