如何使用 SQL 中另一个 table 的 CAST 和信息添加新列?

How to add new column using CAST and info from another table in SQL?

我试图了解 SQL 中两个操作之间的关系 - ADD COLUMN 和 CAST()。 我试图创建一个包含另一列值的长度的新列,而另一列的类型不方便 INTEGER:

ALTER TABLE inventory 
    ADD inventory_id_len AS (CHAR_LENGTH(CAST(inventory_id AS VARCHAR)) FROM rental);

但是 returns:

ERROR:  syntax error at or near "AS"
LINE 4:  ADD inventory_id_len AS (CHAR_LENGTH(CAST(inventory_id AS V...

谢谢。

如果要将id的长度添加为生成列:

ALTER TABLE inventory 
    ADD inventory_id_len INT GENERATED ALWAYS AS (LEN(inventory_id::text) STORED;

因为 Postgres(还)不支持虚拟生成的列,视图可能更符合您的要求:

create view v_inventory as
    select i.*, len(inventory_id::text) as inventory_id_len
    from inventory i;

在 Postgres 中,您需要 use generated always ... stored 语法来添加计算列。对于您的用例,它看起来像:

alter table inventory 
    add inventory_id_len int 
    generated always as (char_length(inventory_id::text)) stored
;

子查询在那种情况下没有意义;计算列采用同一行上的列 inventory_id 的值。