Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Commit440c5ee

Browse files
committed
Restore the ability to run pl/pgsql expression queries in parallel.
pl/pgsql's notion of an "expression" is very broad, encompassingany SQL SELECT query that returns a single column and no more thanone row. So there are cases, for example evaluation of an aggregatefunction, where the query involves significant work and it'd be usefulto run it with parallel workers. This used to be possible, butcommits3eea7a0 et al unintentionally disabled it.The simplest fix is to make exec_eval_expr() pass maxtuples = 0rather than 2 to exec_run_select(). This avoids the new rule thatwe will never use parallelism when a nonzero "count" limit is passedto ExecutorRun(). (Note that the pre-3eea7a0c9 behavior was indeedunsafe, so reverting that rule is not in the cards.) The reasonfor passing 2 before was that exec_eval_expr() will throw an errorif it gets more than one returned row, so we figured that as soonas we have two rows we know that will happen and we might as wellstop running the query. That choice was cost-free when it was made;but disabling parallelism is far from cost-free, so now passing 2amounts to optimizing a failure case at the expense of useful cases.An expression query that can return more than one row is certainlybroken. People might now need to wait a bit longer to discover suchbreakage; but hopefully few will use enormously expensive cases astheir first test of new pl/pgsql logic.Author: Dipesh Dhameliya <dipeshdhameliya125@gmail.com>Reviewed-by: Tom Lane <tgl@sss.pgh.pa.us>Discussion:https://postgr.es/m/CABgZEgdfbnq9t6xXJnmXbChNTcWFjeM_6nuig41tm327gYi2ig@mail.gmail.comBackpatch-through: 13
1 parent8d1071e commit440c5ee

File tree

1 file changed

+5
-1
lines changed

1 file changed

+5
-1
lines changed

‎src/pl/plpgsql/src/pl_exec.c‎

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5703,7 +5703,7 @@ exec_eval_expr(PLpgSQL_execstate *estate,
57035703
/*
57045704
* Else do it the hard way via exec_run_select
57055705
*/
5706-
rc=exec_run_select(estate,expr,2,NULL);
5706+
rc=exec_run_select(estate,expr,0,NULL);
57075707
if (rc!=SPI_OK_SELECT)
57085708
ereport(ERROR,
57095709
(errcode(ERRCODE_WRONG_OBJECT_TYPE),
@@ -5757,6 +5757,10 @@ exec_eval_expr(PLpgSQL_execstate *estate,
57575757

57585758
/* ----------
57595759
* exec_run_selectExecute a select query
5760+
*
5761+
* Note: passing maxtuples different from 0 ("return all tuples") is
5762+
* deprecated because it will prevent parallel execution of the query.
5763+
* However, we retain the parameter in case we need it someday.
57605764
* ----------
57615765
*/
57625766
staticint

0 commit comments

Comments
 (0)

[8]ページ先頭

©2009-2025 Movatter.jp