我在PostgreSQL中有一个包含数字的列。列的数据类型是双精度,并且数字有很多十进制数字。我不需要那么高的准确度。整数就足够了。
如何将列重新定义为具有整数数据类型,同时舍入当前现有数据以获取整数?
答案 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