From: Tom Lane Date: Tue, 19 Nov 2019 19:43:37 +0000 (-0500) Subject: Doc: clarify use of RECURSIVE in WITH. X-Git-Tag: REL_10_12~89 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=f1155901fa598f3476a489152fbfe37a5833613c;p=thirdparty%2Fpostgresql.git Doc: clarify use of RECURSIVE in WITH. Apparently some people misinterpreted the syntax as being that RECURSIVE is a prefix of individual WITH queries. It's a modifier for the WITH clause as a whole, so state that more clearly. Discussion: https://postgr.es/m/ca53c6ce-a0c6-b14a-a8e3-162f0b2cc119@a-kretschmer.de --- diff --git a/doc/src/sgml/ref/select.sgml b/doc/src/sgml/ref/select.sgml index 4c8b6f1e73d..ec3bb2bd457 100644 --- a/doc/src/sgml/ref/select.sgml +++ b/doc/src/sgml/ref/select.sgml @@ -281,6 +281,14 @@ TABLE [ ONLY ] table_name [ * ] reads all or any of their output. + + When there are multiple queries in the WITH + clause, RECURSIVE should be written only once, + immediately after WITH. It applies to all queries + in the WITH clause, though it has no effect on + queries that do not use recursion or forward references. + + The primary query and the WITH queries are all (notionally) executed at the same time. This implies that the effects of