PLSQL存储过程查询(toplink)返回没有分数的bigdecimal字段

时间:2017-07-21 10:52:20

标签: jdeveloper toplink

我从Java(Toplink)调用存储过程如下:

 PLSQLStoredProcedureCall call = new PLSQLStoredProcedureCall();
 call.setProcedureName("PACK_PORTAL_VIEW.get_payment_details");
 call.addNamedArgument("p_order_id", JDBCTypes.NUMERIC_TYPE);
 call.addNamedOutputArgument("some_variable", JDBCTypes.NUMERIC_TYPE);

 DataReadQuery drQuery = new DataReadQuery();
 drQuery.setCall(call);
 drQuery.addArgument("p_order_id");

 Query query = ((JpaEntityManager) em.getDelegate()).createQuery(drQuery);
 query.setParameter("p_order_id", orderId);

 DatabaseRecord record = (DatabaseRecord) query.getSingleResult();
 record.get("some_variable");

record.get(" some_variable")返回一些存储在带有小数部分的DB中的值,但在java中它是在没有它的情况下编写的

record.get(" some_variable")。getClass()返回BigDecimal.class

如何获取存储在数据库中的小数值?

1 个答案:

答案 0 :(得分:0)

必须使用以下方法:

    /**
 * PUBLIC: Add a named OUT argument to the stored procedure. The databaseType parameter
 * classifies the parameter (JDBCType vs. OraclePLSQLType, simple vs. complex). The extra scale
 * and precision parameters indicates that this parameter, when used in an Anonymous PL/SQL
 * block, requires scale and precision specification
 */
public void addNamedOutputArgument(String procedureParameterName, DatabaseType databaseType,
    int precision, int scale) {
    DatabaseType dt = databaseType.isComplexDatabaseType() ? 
        ((ComplexDatabaseType)databaseType).clone() : databaseType;
    arguments.add(new PLSQLargument(procedureParameterName, originalIndex++, OUT, dt,
        precision, scale));
}