微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决如何使用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 举报,一经查实,本站将立刻删除。