Re: WIP: Faster Expression Processing v4

From: Andres Freund <andres(at)anarazel(dot)de>
To: Peter Eisentraut <peter(dot)eisentraut(at)2ndquadrant(dot)com>
Cc: pgsql-hackers(at)postgresql(dot)org, Heikki Linnakangas <hlinnaka(at)iki(dot)fi>, Doug Doole <ddoole(at)salesforce(dot)com>
Subject: Re: WIP: Faster Expression Processing v4
Date: 2017-03-08 00:14:07
Message-ID: 20170308001407.3xrohkxp33jsglqz@alap3.anarazel.de
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

Hi,

On 2017-03-07 18:46:31 -0500, Peter Eisentraut wrote:
> I looked over
> 0001-Add-expression-dependencies-on-composite-type-whole-.patch. That
> seems useful independent of the things you have following.
>
> Even though it is presented more as a preparatory change, it appears to
> have noticeable user-facing impact, which we should analyze.

Indeed.

> For
> example, in the regression test, the command
>
> alter table tt14t drop column f3;
>
> is now rejected, rightly, but the command
>
> alter table tt14t drop column f3 cascade;
>
> ends up dropping the whole view, which might be a bit surprising. We
> don't support dropping columns from views, so there might be no
> alternative

It seems strictly better than silently breaking the view.

> , but I wonder what else is changing because of this. I
> think that might deserve a bit more analysis and perhaps some test cases.

There are already some tests. More is probably good - if you have
specific cases in mind...

> --- a/src/backend/catalog/dependency.c
> +++ b/src/backend/catalog/dependency.c
> @@ -206,6 +206,9 @@ static bool object_address_present_add_flags(const
> ObjectAddress *object,
> static bool stack_address_present_add_flags(const ObjectAddress *object,
> int flags,
>
> ObjectAddressStack *stack);
> +static void add_type_addresses(Oid typeid, bool include_components,
> ObjectAddresses *addrs);
> +static void add_type_component_addresses(Oid typeid, ObjectAddresses
> *addrs);
> +static void add_class_component_addresses(Oid relid, ObjectAddresses
> *addrs);
> static void DeleteInitPrivs(const ObjectAddress *object);
>
> For some reason, the function add_object_address() is singular, and
> these new functions are plural Clearly, they take a plural argument, so
> your version seems more correct, but I wonder if we should keep that
> consistent.

I named them plural, because add_object_address only adds a single new
entry, but add_type_addresses etc potentially add multiple ones. So I
think plural/singular as used here is actually consistent?

> + * e.g. not to the right thing for column-less
> tables. Note that
>
> Small typo there. (to -> do)

Oops.

> @@ -1639,6 +1641,9 @@ find_expr_references_walker(Node *node,
>
> add_object_address(OCLASS_PROC, funcexpr->funcid, 0,
> context->addrs);
> + /* dependency on type itself already exists via function */
> + add_type_component_addresses(funcexpr->funcresulttype,
> context->addrs);
> +
> /* fall through to examine arguments */
> }
> else if (IsA(node, OpExpr))
>
> Why shouldn't the function itself also depend on the components of its
> return type?

Because that'd make it impossible to change the return type components -
if the return type is baked into the view that's necessary, but for a
"freestanding function" it's not. If you e.g. have a function that just
returns a table's rows, it'd certainly be annoying if that'd prevent you
from dropping columns.

> How are argument types handled?

We fall through to

return expression_tree_walker(node, find_expr_references_walker,
(void *) context);

which'll add a dependency if necessary. If it's e.g. a table column,
function return type or such we'll add a dependency there.

Greetings,

Andres Freund

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Tom Lane 2017-03-08 00:15:28 Re: WIP: [[Parallel] Shared] Hash
Previous Message legrand legrand 2017-03-08 00:02:48 Re: Statement-level rollback