0

DB2 的 JDBC 驱动程序似乎截断了 Numeric/Decimal 字段的精度。我在 SALES 表中定义了以下字段:

十进制数 (16,16)

然后我执行以下插入语句:

插入销售(金额)值(14.12345678)

如果我使用 DB2 Control Center 中的查询工具进行查询,我会得到 14.1234567800000000。

如果我使用 Squirrel(一个使用 DB2 的 JDBC 驱动程序连接到数据库的 DB 客户端,我得到 14.12346。当我使用 Hibernate 从 Java 代码执行相同操作时也会发生同样的情况。

这让我相信 JDBC 驱动程序正在截断结果的精度。有没有办法用选项来配置 JDBC 驱动程序来防止这种情况发生?我已经看到了 JDBC 驱动程序的 JDBC 选项,但似乎没有一个描述影响这一点的选项。

4

1 回答 1

1

如果记录被正确插入到数据库中,那么在获取时,它可能会被隐式格式化/截断。

我在使用 Toad for Oracle 检索记录时遇到了类似的问题。然后我手动配置了首选项以使其正确显示,但对 DB2 不熟悉。

您可以尝试在列定义中配置它。 @Column(precision=16, scale=8)BigDecimal领域。

精度:小数(精确数字)列的精度。(仅在使用小数列时适用。)

scale :小数(精确数字)列的比例。(仅在使用小数列时适用。)

精度是总位数,比例是小数点右侧的位数。尝试更改它们的值,目前似乎不合适。

于 2013-04-10T05:21:37.923 回答