From 62fc2eabfa5a7914d9c4000b21b42c2adad394bb Mon Sep 17 00:00:00 2001 From: Remington Steed Date: Mon, 26 Nov 2018 14:10:36 -0500 Subject: [PATCH] Docs: LP#1731048: Update json_query documentation for new join syntax This commit simply adds the text from the related commit message (see LP#1527731) to the original DocBook file. NOTE: This documentation is also available on the wiki, and has been updated there as well: https://wiki.evergreen-ils.org/doku.php?id=documentation:tutorials:json_query Signed-off-by: Remington Steed --- docs/TechRef/JSONTutorial.xml | 76 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 76 insertions(+) diff --git a/docs/TechRef/JSONTutorial.xml b/docs/TechRef/JSONTutorial.xml index 5ea28c38b9..f91678d09b 100644 --- a/docs/TechRef/JSONTutorial.xml +++ b/docs/TechRef/JSONTutorial.xml @@ -2194,6 +2194,82 @@ + Choosing the Order of JOINs + As of Evergreen 3.0.2, we support user-defined join order in cstore and friends. + Previously, because the join structure of oils_sql beyond the specification of + a single table was only allowed to be represented as a JSON object, it was + subject to potential hash key reordering. By supporting an + intervening array layer, one can now specify the exact join order of the + tables in a join tree. + + For example, given the following JSON object passing through a modern Perl 5 + interpreter as a nested hash: + + + + {select : {acp:['id'], + acn:['record'], + acpl:['name'] + }, + from : {acp: + {acn:{filter:{record:12345}}, + acpl:null + } + } + } + + + + the FROM clause of the query may end up as: + + + + FROM acp + JOIN acn ON (acp.call_number = acn.id AND acn.record = 12345) + JOIN acpl ON (acp.location = acpl.id) + + + + Or as: + + + + FROM acp + JOIN acpl ON (acp.location = acpl.id) + JOIN acn ON (acp.call_number = acn.id AND acn.record = 12345) + + + + In some situations, the join order will matter either to the semantics of the + query plan, or to its performance. The following example of the newly + supported syntax illustrates how to specify join order: + + + + {select : {acp:['id'], + acn:['record'], + acpl:['name'] + }, + from : {acp:[ + {acn:{filter:{record:12345}}}, + 'acpl' + ]} + } + + + + And the only FROM clause the can be generated is: + + + + FROM acp + JOIN acn ON (acp.call_number = acn.id AND acn.record = 12345) + JOIN acpl ON (acp.location = acpl.id) + + + + + Things You Can't Do In a JOIN, as with other SQL constructs, there are some things that you can't do with a JSON query. -- 2.11.0