Re: BUG #18114: FULL JOIN is replaced by LEFT JOIN in plan

From: Ilya Anfimov <ilan(at)tzirechnoy(dot)com>
To: pgsql-bugs(at)lists(dot)postgresql(dot)org
Subject: Re: BUG #18114: FULL JOIN is replaced by LEFT JOIN in plan
Date: 2023-09-16 17:06:39
Message-ID: ZQXgn6Dz2sjDnkrv@azor.tzirechnoy.ru
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

On Sat, Sep 16, 2023 at 11:32:15PM +1000, W??i C??ngru?? wrote:
> This is not a bug. The row is filtered by the WHERE clause.
> Sorry for disturbing.
>
> On Sat, Sep 16, 2023, 22:36 PG Bug reporting form <noreply(at)postgresql(dot)org>
> wrote:
>
> The following bug has been logged on the website:
>
> Bug reference: 18114
> Logged by: crvv
> Email address: crvv(dot)mail(at)gmail(dot)com
> PostgreSQL version: 16.0
> Operating system: Linux
> Description:
>
> SELECT * FROM (VALUES (1)) AS t(id)
> CROSS JOIN unnest('{1,2}'::int[]) AS a(x)
> FULL JOIN unnest('{2,3}'::int[]) AS b(x) ON a.x = b.x
> WHERE t.id = 1
>
> Execute this SQL, I get the result
> id | x | x
> ----+---+---
> 1 | 1 |
> 1 | 2 | 2
>
> My expection is
> id | x | x
> ----+---+---
> 1 | 1 |
> 1 | 2 | 2
> | | 3

Your expectation is incorrect.
Last record has null t.id (not 1), so it was
filtered out by WHERE.

In response to

Responses

Browse pgsql-bugs by date

  From Date Subject
Next Message Michael Paquier 2023-09-16 23:50:13 Re: BUG #18070: Assertion failed when processing error from plpy's iterator
Previous Message Alexander Lakhin 2023-09-16 17:00:00 Re: BUG #18070: Assertion failed when processing error from plpy's iterator