diff options
| author | Heikki Linnakangas <heikki.linnakangas@iki.fi> | 2025-05-19 18:50:26 +0300 | 
|---|---|---|
| committer | Heikki Linnakangas <heikki.linnakangas@iki.fi> | 2025-05-19 18:50:52 +0300 | 
| commit | 72fe74ca533375fa04264f976d4c4971c6804dce (patch) | |
| tree | 7eecc1553c3bd8ae05fdf190613e9c393b964778 /src/backend/storage/freespace/freespace.c | |
| parent | 9d1a6235960697b5dbc5e0b7d56d59c0a6de3b3d (diff) | |
Fix deparsing FETCH FIRST <expr> ROWS WITH TIES
In the grammar, <expr> is a c_expr, which accepts only a limited set
of integer literals and simple expressions without parens. The
deparsing logic didn't quite match the grammar rule, and failed to use
parens e.g. for "5::bigint".
To fix, always surround the expression with parens. Would be nice to
omit the parens in simple cases, but unfortunately it's non-trivial to
detect such simple cases. Even if the expression is a simple literal
123 in the original query, after parse analysis it becomes a FuncExpr
with COERCE_IMPLICIT_CAST rather than a simple Const.
Reported-by: yonghao lee
Backpatch-through: 13
Discussion: https://www.postgresql.org/message-id/18929-077d6b7093b176e2@postgresql.org
Diffstat (limited to 'src/backend/storage/freespace/freespace.c')
0 files changed, 0 insertions, 0 deletions
