Oracle
 sql >> Database >  >> RDS >> Oracle

Lottando con la primavera SimpleJdbcCall per chiamare la funzione Oracle

Sembra che tu usi una chiamata al metodo non corretta:Il tuo codice:.withProcedureName("MYFUNCTION")[..] deve essere sostituito da .withFunctionName[...]

ecco un semplice esempio di chiamata di intera funzione:

JdbcTemplate jdbc = new JdbcTemplate(txManager.getDataSource());
    SimpleJdbcCall jdbcCall = new SimpleJdbcCall(jdbc)
            .withCatalogName("p_adm_www")
            .withFunctionName("fn_usr_get_login_sequence")
            .declareParameters(new SqlOutParameter("RETURN", OracleTypes.NUMBER))
            .withoutProcedureColumnMetaDataAccess();
    jdbcCall.setAccessCallParameterMetaData(false);
    BigDecimal returnId = jdbcCall.executeFunction(BigDecimal.class, null);
    return returnId.longValue();