0

如果有人可以帮助我一点,我将不胜感激。我对 Postrgresql 10 完全陌生,我有一个大文件,有数百万行 73 列,我无法导入,所以我将所有列设置为 varchar。现在我需要操作无法更改数据类型的数据。我试了几个小时。该列包含一些带有 1 位或 2 位小数的值。这就是我正在做的事情:

ALTER TABLE table1 
ALTER COLUMN facevalue TYPE numeric USING (facevalue::numeric);

这是我得到的错误

ERROR:  invalid input syntax for type numeric: " "
SQL state: 22P02

感谢您的时间和考虑

4

1 回答 1

1

你显然有空字符串或只有空格的值。您需要将它们转换为 NULL

ALTER TABLE table1 
   ALTER COLUMN facevalue TYPE numeric USING (nullif(trim(facevalue),'')::numeric);
于 2020-05-17T20:20:32.237 回答