我正在更改已经填充列的现有表。在我的表"部分"中,我想对"名称"列设置字符限制,特别是键入VARCHAR(60(。但是,以前没有字符限制,我想截断名称列中的任何现有字段,以便它现在在我的 ALTER 脚本之前匹配此限制。
我仍然收到一些错误消息,包括在我的 LEFT 语句中,这是我用来截断"name"列中的字符串的。LEFT 语句对我声明要截断的字符串的方式感到不安,无论我是否将参数放在括号中。这就是我目前所处的位置:
DO $$
DECLARE
_name text;
_id uuid;
BEGIN
FOR _name, _id IN SELECT (name, id) FROM %SCHEMA%.section
LOOP
IF (_name > 60)
THEN
SET name = LEFT (_name, 60) WHERE id = _id;
END IF;
END LOOP;
RETURN NEW;
END $$;
完成此操作后,我知道我的 ALTER 脚本非常简单:
ALTER TABLE IF EXISTS %SCHEMA%.section ALTER COLUMN name TYPE VARCHAR(60);
您还可以使用USING
语法来ALTER TABLE
。 这允许您将其作为 ALTER 的一部分执行,而不是作为两个单独的命令。
ALTER TABLE myschema.mytable
ALTER COLUMN mycolumn
TYPE VARCHAR(60)
USING LEFT(mycolumn, 60);
https://www.postgresql.org/docs/9.6/static/sql-altertable.html
使用更新查询,如下所示:
UPDATE myschema.mytable
SET name = LEFT(mytable.name, 60)
WHERE LENGTH(mytable.name) > 60