首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Postgresql将列类型从UUID更改为int4

Postgresql将列类型从UUID更改为int4
EN

Stack Overflow用户
提问于 2020-04-04 19:14:22
回答 2查看 698关注 0票数 0

我想将column的dataType从UUID更改为int4

代码语言:javascript
复制
ALTER TABLE tableA ALTER COLUMN columnA TYPE int4(32);

但它给了我一个错误。

代码语言:javascript
复制
ERROR: type modifier is not allowed for type "int4"

我试着在互联网上搜索,发现我必须使用USING,但不知道如何使用它。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-04-04 19:47:30

您不能真正将UID转换为int。值太多了,因此存在冲突的风险(随着表变得更大,冲突的风险会上升到100% )。

我的猜测是,您确实希望在表中有一个id列。如果是,则添加新列并删除旧列:

代码语言:javascript
复制
alter table tableA add a_id int generated always as identity,
                   drop columnA;

注意:在旧版本的Postgres中,您应该使用serial而不是int generated always as identity

票数 1
EN

Stack Overflow用户

发布于 2020-04-04 19:21:01

您的32在语法上被视为修饰语。修饰符允许用于数字和小数类型,但不允许用于普通整数,int4(xxx)在Postgres中不是有效类型(我相信它在mysql中) int4只是integer的别名。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61027222

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档