问题描述
我试图了解sql中两个操作之间的关系-ADD COLUMN和CAST()。 我试图创建一个包含另一列值的长度的新列,而另一列的类型为INTEGER则很不方便:
ALTER TABLE inventory
ADD inventory_id_len AS (CHAR_LENGTH(CAST(inventory_id AS VARCHAR)) FROM rental);
但是它返回:
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
的值。