问题描述
我正在尝试使用以下查询将列大小从100更改为150 varchar数据类型:
alter table data_warehouse.tbl_abc
alter column first_nm varchar(150) null;
出现以下错误:
解决方法
语法略有不同,因此请尝试以下操作:
ALTER TABLE data_warehouse.tbl_abc
ALTER COLUMN first_nm type varchar(120);
,
语法错误是您错过了TYPE
关键字:
ALTER TABLE data_warehouse.tbl_abc
ALTER COLUMN first_nm TYPE varchar(150);
,如果您有一个要删除的NOT NULL
约束,请在同一ALTER COLUMN
语句内添加一个新的ALTER TABLE
:
ALTER TABLE data_warehouse.tbl_abc
ALTER COLUMN first_nm TYPE varchar(150),ALTER COLUMN first_nm DROP NOT NULL;
以供参考:https://www.postgresql.org/docs/current/sql-altertable.html
编辑:如注释中所述,如果您有一个涉及同一列的视图,请将其拖放并在事务下重新创建它:
BEGIN TRANSACTION;
DROP VIEW [...];
ALTER TABLE [...];
CREATE VIEW [...];
COMMIT;
请注意,要更改表,您必须获得对该表的排他锁,因此在整个过程中,同一表以及该表视图上的所有查询都将被锁定,即使它们未读取也是如此。从更改的列中删除(因为整个表已锁定)-在生产环境中谨慎使用