在 PostgreSQL 交互式终端中输入以下命令会导致错误:
ALTER TABLE tbl_name ALTER COLUMN col_name varchar (11);
更改列数据类型的正确命令是什么?
请参阅此处的文档:http://www.postgresql.org/docs/current/interactive/sql-altertable.html
ALTER TABLE tbl_name ALTER COLUMN col_name TYPE varchar (11);
如果列中已经存在数据,您应该执行以下操作:
ALTER TABLE tbl_name ALTER COLUMN col_name TYPE integer USING col_name::integer;
正如@nobu 和@jonathan-porter 在对@derek-kromm 答案的评论中指出的那样,有点神秘。
酷@derek-kromm,您的回答已被接受且正确,但我想知道我们是否需要alter
多于专栏。这是我们可以做的。
ALTER TABLE tbl_name
ALTER COLUMN col_name TYPE varchar (11),
ALTER COLUMN col_name2 TYPE varchar (11),
ALTER COLUMN col_name3 TYPE varchar (11);
干杯!!读简单 写简单
ALTER TABLE tbl_name ALTER COLUMN col_name TYPE integer USING col_name::integer;
some cases
中这样做,这些情况是什么?