Re: Using Expanded Objects other than Arrays from plpgsql - Mailing list pgsql-hackers
From | Tom Lane |
---|---|
Subject | Re: Using Expanded Objects other than Arrays from plpgsql |
Date | |
Msg-id | 931398.1737905825@sss.pgh.pa.us Whole thread Raw |
In response to | Re: Using Expanded Objects other than Arrays from plpgsql (Andrey Borodin <x4mmm@yandex-team.ru>) |
Responses |
Re: Using Expanded Objects other than Arrays from plpgsql
|
List | pgsql-hackers |
Andrey Borodin <x4mmm@yandex-team.ru> writes: >> On 21 Jan 2025, at 23:12, Tom Lane <tgl@sss.pgh.pa.us> wrote: >> somebody will review this > I'm trying to dig into the patch set. My knowledge of the module is shallow and I hope to improve it by reading more patchesin this area. Thanks for looking! > And the coverage of newly invented mark_stmt() 42.37%. Some of branches are easy noops, but some are not. Yeah. I'm not too concerned about that because it's pretty much a copy-and-paste of the adjacent code. Maybe we should think about some way of refactoring pl_funcs.c to reduce duplication, but I don't have any great ideas about how. > expr_is_assignment_source() is named like if it should return nool, but it's void. I've been less than satisfied with that name too. I intended it as a statement of fact, "this expression has been found to be the source of an assignment". But it does seem confusing. Maybe we should recast it as an action. What do you think of "mark_expr_as_assignment_source"? > I could not grasp from reading the code one generic question about new optimization rule. What cost does checking for possiblein-place update incurs to code cannot have this optimization? Is it O(numer_of_arguments) of for every assignmentexecution? No, the extra effort is incurred at most once per assignment statement per session. (Unless the plpgsql function's cache entry gets invalidated, in which case we'd rebuild all of the function's data structures and have to redo this work too.) We set up the evaluation function "paramfunc" as plpgsql_param_eval_var_check if we think we might be able to apply this optimization, or plpgsql_param_eval_var_ro if we don't think so but the variable is of varlena type. At runtime, if the variable's current value is not actually expanded, then plpgsql_param_eval_var_check falls through doing essentially the same work as plpgsql_param_eval_var_ro, so there should be no added cost. The first time we observe that the value *is* expanded, we incur the cost to detect whether an optimization is really possible, and then we change the "paramfunc" pointer to be the appropriate function so as to apply the optimization or not without rechecking. So generally speaking, if we're considering a variable of a type that doesn't support expansion, there should be zero extra per-execution cost. There is some extra cost at function compilation time to determine which expressions are assignment sources (but we were doing that already) and to discover whether those assignments are to nonlocal variables (which is new work, but only needs to be done in functions with exception blocks). regards, tom lane
pgsql-hackers by date: