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