BUG #18634: Wrong varnullingrels with merge ... when not matched by source - Mailing list pgsql-bugs

From PG Bug reporting form
Subject BUG #18634: Wrong varnullingrels with merge ... when not matched by source
Date
Msg-id 18634-db5299c937877f2b@postgresql.org
Whole thread Raw
Responses Re: BUG #18634: Wrong varnullingrels with merge ... when not matched by source
List pgsql-bugs
The following bug has been logged on the website:

Bug reference:      18634
Logged by:          Alexander Lakhin
Email address:      exclusion@gmail.com
PostgreSQL version: 17.0
Operating system:   Ubuntu 22.04
Description:

The following script:
CREATE TABLE t (a int);
INSERT INTO t VALUES(1), (2);
CREATE VIEW v AS SELECT a FROM t WHERE EXISTS (SELECT 1 FROM t);

MERGE INTO v USING (SELECT * FROM generate_series(1,1)) AS s(a)
  ON s.a = v.a WHEN NOT MATCHED BY SOURCE THEN DELETE;

produces:
ERROR:  XX000: wrong varnullingrels (b) (expected (b 4)) for Var 5/1
LOCATION:  search_indexed_tlist_for_var, setrefs.c:2847

At the same time,
MERGE INTO v USING (SELECT * FROM generate_series(1,1)) AS s(a)
  ON s.a = v.a WHEN MATCHED THEN DELETE;
planned and executed with no error.


pgsql-bugs by date:

Previous
From: Tender Wang
Date:
Subject: Re: BUG #18630: Incorrect memory access inside ReindexIsProcessingIndex() on VACUUM
Next
From: Tom Lane
Date:
Subject: Re: BUG #18634: Wrong varnullingrels with merge ... when not matched by source