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

我在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

相关文章

文章浏览阅读601次。Oracle的数据导入导出是一项基本的技能,...
文章浏览阅读553次。开头还是介绍一下群,如果感兴趣polardb...
文章浏览阅读3.5k次,点赞3次,收藏7次。折腾了两个小时多才...
文章浏览阅读2.7k次。JSON 代表 JavaScript Object Notation...
文章浏览阅读2.9k次,点赞2次,收藏6次。navicat 连接postgr...
文章浏览阅读1.4k次。postgre进阶sql,包含分组排序、JSON解...