如何解决如何使用CAST和SQL中另一个表的信息添加新列?
我试图了解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
的值。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。