aboutsummaryrefslogtreecommitdiff
path: root/src/test/perl/git@kaiwu.me:public/postgresql
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2025-07-03 17:39:53 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2025-07-03 17:39:53 -0400
commit931766aaec58b2ce09c82203456877e0b05e1271 (patch)
treed07c8d32603eb4101650b0f3bfcef287d5e49bd3 /src/test/perl/git@kaiwu.me:public/postgresql
parentfc896821c4448038c5cc678c1aff7349ee850b23 (diff)
downloadpostgresql-931766aaec58b2ce09c82203456877e0b05e1271.tar.gz
postgresql-931766aaec58b2ce09c82203456877e0b05e1271.zip
Simplify COALESCE() with one surviving argument.
If, after removal of useless null-constant arguments, a CoalesceExpr has exactly one remaining argument, we can just take that argument as the result, without bothering to wrap a new CoalesceExpr around it. This isn't likely to produce any great improvement in runtime per se, but it can lead to better plans since the planner no longer has to treat the expression as non-strict. However, there were a few regression test cases that intentionally wrote COALESCE(x) as a shorthand way of creating a non-strict subexpression. To avoid ruining the intent of those tests, write COALESCE(x,x) instead. (If anyone ever proposes de-duplicating COALESCE arguments, we'll need another iteration of this arms race. But it seems pretty unlikely that such an optimization would be worthwhile.) Author: Maksim Milyutin <maksim.milyutin@tantorlabs.ru> Reviewed-by: Tom Lane <tgl@sss.pgh.pa.us> Discussion: https://postgr.es/m/8e8573c3-1411-448d-877e-53258b7b2be0@tantorlabs.ru
Diffstat (limited to 'src/test/perl/git@kaiwu.me:public/postgresql')
0 files changed, 0 insertions, 0 deletions