From: | Richard Guo <guofenglinux(at)gmail(dot)com> |
---|---|
To: | Peter Eisentraut <peter(at)eisentraut(dot)org> |
Cc: | pgsql-hackers <pgsql-hackers(at)postgresql(dot)org>, jian he <jian(dot)universality(at)gmail(dot)com>, Dean Rasheed <dean(dot)a(dot)rasheed(at)gmail(dot)com> |
Subject: | Re: Virtual generated columns |
Date: | 2025-01-08 08:22:47 |
Message-ID: | CAMbWs48Ki7vScBfO0_JD_LTFPwbS-Vi-HKqQfg8ZK34OL0APKg@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
On Fri, Nov 29, 2024 at 7:14 PM Peter Eisentraut <peter(at)eisentraut(dot)org> wrote:
> Here is a new patch version, with several updates.
> - Added support for ALTER TABLE ... SET EXPRESSION.
When using ALTER TABLE to set expression for virtual generated
columns, we don't enforce a rewrite, which means we don't have the
opportunity to check whether the new values for these columns could
cause an underflow or overflow. For instance,
create table t (a int, b int generated always as (a) virtual);
insert into t values (2147483647);
# alter table t alter column b set expression as (a * 2);
ALTER TABLE
# select * from t;
ERROR: integer out of range
The same thing could occur with INSERT. As we don't compute virtual
generated columns on write, we may end up inserting values that cause
underflow or overflow for these columns.
create table t1 (a int, b int generated always as (a * 2) virtual);
insert into t1 values (2147483647);
# select * from t1;
ERROR: integer out of range
I'm not sure if this is expected or not, so I just wanted to point it
out.
Thanks
Richard
From | Date | Subject | |
---|---|---|---|
Next Message | cca5507 | 2025-01-08 08:43:32 | Fix a wrong errmsg in AlterRole() |
Previous Message | Yugo NAGATA | 2025-01-08 08:14:30 | Re: EphemeralNamedRelation and materialized view |