Re: SEARCH and CYCLE clauses

From: Anastasia Lubennikova <a(dot)lubennikova(at)postgrespro(dot)ru>
To: Pavel Stehule <pavel(dot)stehule(at)gmail(dot)com>, Peter Eisentraut <peter(dot)eisentraut(at)2ndquadrant(dot)com>
Cc: pgsql-hackers <pgsql-hackers(at)postgresql(dot)org>
Subject: Re: SEARCH and CYCLE clauses
Date: 2020-10-27 19:31:19
Message-ID: 29af2c49-5f85-a7d4-7d5b-e35aab1c5357@postgrespro.ru
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On 10.10.2020 08:25, Pavel Stehule wrote:
> Hi
>
> pá 9. 10. 2020 v 12:17 odesílatel Pavel Stehule
> <pavel(dot)stehule(at)gmail(dot)com <mailto:pavel(dot)stehule(at)gmail(dot)com>> napsal:
>
>
>
> pá 9. 10. 2020 v 11:40 odesílatel Peter Eisentraut
> <peter(dot)eisentraut(at)2ndquadrant(dot)com
> <mailto:peter(dot)eisentraut(at)2ndquadrant(dot)com>> napsal:
>
> On 2020-09-22 20:29, Pavel Stehule wrote:
> > The result is correct. When I tried to use UNION instead
> UNION ALL, the
> > pg crash
>
> I fixed the crash, but UNION [DISTINCT] won't actually work
> here because
> row/record types are not hashable.  I'm leaving the partial
> support in,
> but I'm documenting it as currently not supported.
>
>  I think so UNION is a common solution against the cycles. So
> missing support for this specific case is not a nice thing. How
> much work is needed for hashing rows. It should not be too much code.
>
>
> > looks so clause USING in cycle detection is unsupported for
> DB2 and
> > Oracle - the examples from these databases doesn't work on
> PG without
> > modifications
>
> Yeah, the path clause is actually not necessary from a user's
> perspective, but it's required for internal bookkeeping.  We
> could
> perhaps come up with a mechanism to make it invisible coming
> out of the
> CTE (maybe give the CTE a target list internally), but that
> seems like a
> separate project.
>
> The attached patch fixes the issues you have reported (also
> the view
> issue from the other email).  I have also moved the whole rewrite
> support to a new file to not blow up rewriteHandler.c so much.
>
> --
> Peter Eisentraut http://www.2ndQuadrant.com/
> PostgreSQL Development, 24x7 Support, Remote DBA, Training &
> Services
>
>
> This patch is based on transformation CYCLE and SEARCH clauses to
> specific expressions - it is in agreement with ANSI SQL
>
> There is not a problem with compilation
> Nobody had objections in discussion
> There are enough regress tests and documentation
> check-world passed
> doc build passed
>
> I'll mark this patch as ready for committer
>
> Possible enhancing for this feature (can be done in next steps)
>
> 1. support UNION DISTINCT
> 2. better compatibility with Oracle and DB2 (USING clause can be optional)
>
> Regards
>
> Pavel
>
>
>
>
Status update for a commitfest entry.
According to cfbot patch no longer applies. So I moved it to waiting on
author.

--
Anastasia Lubennikova
Postgres Professional: http://www.postgrespro.com
The Russian Postgres Company

In response to

Browse pgsql-hackers by date

  From Date Subject
Next Message Andres Freund 2020-10-27 19:36:09 Re: cutting down the TODO list thread
Previous Message John Naylor 2020-10-27 19:24:35 cutting down the TODO list thread