0

我注意到 nzsql 和 'nzunload' 只是截断双精度列的尾数值。这是问题:

从表1中选择tot_amt

tot_amt
~~~~~~~    
123.124    
567.678

而当我使用 Aginity 等其他客户端进行数据分析时 - 我得到的输出是

tot_amt
~~~~~~~
123.1240535
567.6780122

我还发现当 netezza 在 3 个尾数位后遇到 0 时会发生“截断”。

我们正在尝试将此数据库迁移到 oracle,由于这个问题,整个项目都被搞砸了,客户不信任我们的迁移脚本。有没有人遇到过这个问题?唯一的解决方法,即使是 frmo IBM 工程师也是强制转换它TO_CHAR( '999,999.999', col )如果我必须为数十亿行执行此操作,这将杀死卸载脚本。

4

1 回答 1

0

我可以重现此问题,其中我创建了一个列为 FLOAT(6) 的表,例如:

USERDB.USER(USER)=> create table ZZ (
USERDB.USER(USER)(> YY FLOAT(6)
USERDB.USER(USER)(> );
CREATE TABLE
USERDB.USER(USER)=> insert into ZZ (yy) values (123.123456789);
INSERT 0 1
USERDB.USER(USER)=> insert into ZZ (yy) values (12.123456789);
INSERT 0 1
USERDB.USER(USER)=> select * from ZZ;
   YY
---------
 123.123
 12.1234
(2 rows)

USERDB.USER(USER)=> select CAST ( YY as FLOAT(15) ) from ZZ;
    ?COLUMN?
----------------
 123.1234588623
12.123399734497
(2 rows)

USERDB.USER(USER)=>

我可以将列值转换为更广泛的类型,但是我看到的问题是我插入的值与返回的值不同。如果我也使用 Aginity 进行查询也是如此,值不正确。

检查表 1 中“tot_amt”列的精度(和比例),我猜用于存储值的数据类型非常小(可能是 FLOAT(6)?),并且 NZSQL 告诉您数据强制执行的正确值类型。

于 2016-06-23T22:23:23.727 回答