Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Clarifications about the use of ToList in algebra expressions #140

Merged
merged 5 commits into from
Mar 7, 2024
Merged
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
31 changes: 21 additions & 10 deletions spec/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -8840,8 +8840,11 @@ <h4>Examples of Mapped Graph Patterns</h4>
Join(<br>
&nbsp;&nbsp; BGP(?s :p ?o) ,<br>
&nbsp;&nbsp; ToMultiSet(<br>
&nbsp;&nbsp;&nbsp;&nbsp; Distinct(Project(BGP(?o ?p ?z), {?o})) )<br>
&nbsp;&nbsp; )
&nbsp;&nbsp;&nbsp;&nbsp; Distinct( <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Project( ToList(BGP(?o ?p ?z)), {?o} ) <br>
&nbsp;&nbsp;&nbsp;&nbsp; ) <br>
&nbsp;&nbsp; ) <br>
)
</div>
</div>
</section>
Expand Down Expand Up @@ -8994,8 +8997,22 @@ <h5>SELECT Expressions</h5>
</section>
<section id="convertSolMod">
<h4>Converting Solution Modifiers</h4>
<p>Solutions modifiers apply to the processing of a SPARQL query after pattern matching.
The solution modifiers are applied to a query in the following order:</p>
<p>Solution modifiers apply to the processing of a SPARQL query after pattern matching.</p>
<p>However, since the solution modifiers operate on sequences
hartig marked this conversation as resolved.
Show resolved Hide resolved
of solution mappings, the query result produced up to this
point is first turned from a multiset of solution mappings
into such a sequence. While there is no implied ordering to
this sequence, and duplicates need not be adjacent, the sequence
is identical to the multiset in terms of the elements that it
contains, and their multiplicities. To apply this conversion
from a multiset into a sequence, the algorithm for capturing
the solution modifiers in the algebra expression begins with
the following step, where <var>Pattern</var> is the algebra
expression produced by the algorithm in the previous section.</p>
<blockquote>
<p>Let M := ToList(<var>Pattern</var>)</p>
</blockquote>
<p>Now, the solution modifiers are applied in the following order:</p>
<ul>
<li>Order by</li>
<li>Projection</li>
Expand All @@ -9004,12 +9021,6 @@ <h4>Converting Solution Modifiers</h4>
<li>Offset</li>
<li>Limit</li>
</ul>
<p>Step: ToList</p>
<p>ToList turns a multiset into a sequence with the same elements and multiplicities. There is
no implied ordering to the sequence; duplicates need not be adjacent.</p>
<blockquote>
<p>Let M := ToList(Pattern)</p>
</blockquote>
<section id="sparqlOrderBy">
<h5>ORDER BY</h5>
<p>If the query string has an ORDER BY clause</p>
Expand Down
Loading