PostgreSQL:将现有的双精度列转换为整数数据类型

时间:2014-12-15 19:19:12

标签: postgresql

我在PostgreSQL中有一个包含数字的列。列的数据类型是双精度,并且数字有很多十进制数字。我不需要那么高的准确度。整数就足够了。

如何将列重新定义为具有整数数据类型,同时舍入当前现有数据以获取整数?

1 个答案:

答案 0 :(得分:7)

只需更改表格,Postgres将通过适当地舍入来自动将double值转换为整数:

ALTER TABLE foo ALTER COLUMN some_column TYPE integer;

这基本上与:

相同
ALTER TABLE foo ALTER COLUMN some_data TYPE integer 
   USING round(some_data)::integer;

SQLFiddle:http://sqlfiddle.com/#!15/4ea3c/1