如何使用 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
的值。
我试图了解 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
的值。