]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Fix SQL:2008 FETCH FIRST syntax to allow parameters.
authorAndrew Gierth <rhodiumtoad@postgresql.org>
Mon, 21 May 2018 16:02:17 +0000 (17:02 +0100)
committerAndrew Gierth <rhodiumtoad@postgresql.org>
Mon, 21 May 2018 16:32:18 +0000 (17:32 +0100)
commit7a0aa8d12ace1e5e73ccf9cbee88fdde255fe172
tree4a59ab9ef60f604ba3212ec35f5334acf857368a
parent1545ca9a7463f4ae8451a845774a107ad0757a9f
Fix SQL:2008 FETCH FIRST syntax to allow parameters.

OFFSET <x> ROWS FETCH FIRST <y> ROWS ONLY syntax is supposed to accept
<simple value specification>, which includes parameters as well as
literals. When this syntax was added all those years ago, it was done
inconsistently, with <x> and <y> being different subsets of the
standard syntax.

Rectify that by making <x> and <y> accept the same thing, and allowing
either a (signed) numeric literal or a c_expr there, which allows for
parameters, variables, and parenthesized arbitrary expressions.

Per bug #15200 from Lukas Eder.

Backpatch all the way, since this has been broken from the start.

Discussion: https://postgr.es/m/877enz476l.fsf@news-spur.riddles.org.uk
Discussion: http://postgr.es/m/152647780335.27204.16895288237122418685@wrigleys.postgresql.org
doc/src/sgml/ref/select.sgml
src/backend/parser/gram.y