Re: Disallow USING clause when altering type of generated column - Mailing list pgsql-hackers

From jian he
Subject Re: Disallow USING clause when altering type of generated column
Date
Msg-id CACJufxHkv109tQtHt7EtKprWhvVkxtR7-cEBwGzcTovtVTw9_Q@mail.gmail.com
Whole thread Raw
In response to Disallow USING clause when altering type of generated column  (Peter Eisentraut <peter@eisentraut.org>)
Responses Re: Disallow USING clause when altering type of generated column
List pgsql-hackers
On Wed, Aug 21, 2024 at 4:57 PM Peter Eisentraut <peter@eisentraut.org> wrote:
>

+ /*
+ * Cannot specify USING when altering type of a generated column, because
+ * that would violate the generation expression.
+ */
+ if (attTup->attgenerated && def->cooked_default)
+ ereport(ERROR,
+ (errcode(ERRCODE_INVALID_TABLE_DEFINITION),
+ errmsg("cannot specify USING when altering type of generated column"),
+ errdetail("Column \"%s\" is a generated column.", colName)));
+

errcode should be ERRCODE_FEATURE_NOT_SUPPORTED?

also
CREATE TABLE gtest27 (
    a int,
    b text collate "C",
    x text GENERATED ALWAYS AS ( b || '_2') STORED
);

ALTER TABLE gtest27 ALTER COLUMN x TYPE int;
ERROR:  column "x" cannot be cast automatically to type integer
HINT:  You might need to specify "USING x::integer".

should we do something for the errhint, since this specific errhint is wrong?



pgsql-hackers by date:

Previous
From: shveta malik
Date:
Subject: Re: Conflict detection and logging in logical replication
Next
From: Amit Langote
Date:
Subject: Re: pgsql: Add more SQL/JSON constructor functions