【发布时间】:2013-04-09 23:59:09
【问题描述】:
DB2 的 JDBC 驱动程序似乎正在截断数字/十进制字段的精度。我在 SALES 表中定义了以下字段:
十进制数(16,16)
然后我执行以下插入语句:
插入销售额(金额)值 (14.12345678)
如果我使用 DB2 控制中心中的查询工具进行查询,我会得到 14.1234567800000000。
如果我使用 Squirrel(一个使用 DB2 的 JDBC 驱动程序连接到数据库的 DB 客户端,我得到 14.12346。当我使用 Hibernate 从 Java 代码执行相同操作时也会发生同样的情况。
这让我相信 JDBC 驱动程序正在截断结果的精度。有没有办法用选项来配置 JDBC 驱动程序来防止这种情况发生?我已经看到了 JDBC 驱动程序的 JDBC 选项,但似乎没有一个描述影响这一点的选项。
【问题讨论】:
-
DECIMAL(16,16)有点奇怪,14.1234567890123456 不适合(至少 a 应该是DECIMAL(18,16))。 -
马克和纳扬是对的。该值不能适合 DB2 中的 DECIMAL(16,16) 列。 DECIMAL(16,16) 小数点左侧没有数字。俗话说,你不能把 10 磅的____装进一个 5 磅的袋子里。也许你在这里打错了?
-
是的。我实际上误解并认为精度在小数点之前和小数点之后。我们实际的数据库表有 DECIMAL(19,8)。指定比例和精度后,它可以正常工作。