Re: [HACKERS] path toward faster partition pruning

From: Alvaro Herrera <alvherre(at)alvh(dot)no-ip(dot)org>
To: David Rowley <david(dot)rowley(at)2ndquadrant(dot)com>
Cc: Amit Langote <Langote_Amit_f8(at)lab(dot)ntt(dot)co(dot)jp>, Jesper Pedersen <jesper(dot)pedersen(at)redhat(dot)com>, Robert Haas <robertmhaas(at)gmail(dot)com>, Ashutosh Bapat <ashutosh(dot)bapat(at)enterprisedb(dot)com>, Rajkumar Raghuwanshi <rajkumar(dot)raghuwanshi(at)enterprisedb(dot)com>, Kyotaro HORIGUCHI <horiguchi(dot)kyotaro(at)lab(dot)ntt(dot)co(dot)jp>, Amit Langote <amitlangote09(at)gmail(dot)com>, Dilip Kumar <dilipbalaut(at)gmail(dot)com>, Beena Emerson <memissemerson(at)gmail(dot)com>, "pgsql-hackers(at)postgresql(dot)org" <pgsql-hackers(at)postgresql(dot)org>
Subject: Re: [HACKERS] path toward faster partition pruning
Date: 2018-04-06 14:54:39
Message-ID: 20180406145439.khnscipj2m5vi2nc@alvherre.pgsql
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

Alvaro Herrera wrote:

> Yeah. Looking at this function, I noticed it tests for BooleanTest, and
> falls back to checking "not_clause" and a few equals. Does it make
> sense if the clause is a SAOP? I added this assert:
> Assert(IsA(clause, BooleanTest) ||
> IsA(clause, BoolExpr) ||
> IsA(clause, RelabelType));
>
> and it failed:
> #3 0x0000556cf04505db in match_boolean_partition_clause (partopfamily=424,
> clause=0x556cf1041670, partkey=0x556cf1042218, rightop=0x7ffe520ec068)
> at /pgsql/source/master/src/backend/optimizer/util/partprune.c:2159
> 2159 Assert(IsA(clause, BooleanTest) ||
> (gdb) print *clause
> $1 = {type = T_ScalarArrayOpExpr}
>
> I'm not sure whether or not this function can trust that what's incoming
> must absolutely be only those node types.

So this is what I need for current regression tests not to crash
anymore:

Assert(IsA(clause, BooleanTest) ||
IsA(clause, BoolExpr) ||
IsA(clause, RelabelType) ||
IsA(clause, ScalarArrayOpExpr) ||
IsA(clause, OpExpr) ||
IsA(clause, Var));

I'm not confident in my ability to write code to handle all possible
cases right now (obviously there must be more cases that are not covered
by current regression tests), so I'll leave it without the assert since
it handles a couple of the useful cases, but I suspect it could stand
some more improvement.

I guess the question is, how interesting is boolean partitioning? I bet
it has its uses.

--
Álvaro Herrera https://www.2ndQuadrant.com/
PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Amit Langote 2018-04-06 15:36:28 Re: [HACKERS] path toward faster partition pruning
Previous Message Alvaro Herrera 2018-04-06 14:40:57 Re: [HACKERS] path toward faster partition pruning