# HG changeset patch # User Adam Chlipala # Date 1328370138 18000 # Node ID 9dd8d47c3e58d7e21c5d150c349e7830045a22fb # Parent be1ed46d73e2012d6be948b953fd305bcb79bc65 Extend and document RANDOM diff -r be1ed46d73e2 -r 9dd8d47c3e58 doc/manual.tex --- a/doc/manual.tex Fri Feb 03 08:30:56 2012 -0500 +++ b/doc/manual.tex Sat Feb 04 10:42:18 2012 -0500 @@ -1848,6 +1848,7 @@ \mt{val} \; \mt{sql\_order\_by\_Nil} : \mt{tables} ::: \{\{\mt{Type}\}\} \to \mt{exps} :: \{\mt{Type}\} \to \mt{sql\_order\_by} \; \mt{tables} \; \mt{exps} \\ \mt{val} \; \mt{sql\_order\_by\_Cons} : \mt{tables} ::: \{\{\mt{Type}\}\} \to \mt{exps} ::: \{\mt{Type}\} \to \mt{t} ::: \mt{Type} \\ \hspace{.1in} \to \mt{sql\_exp} \; \mt{tables} \; [] \; \mt{exps} \; \mt{t} \to \mt{sql\_direction} \to \mt{sql\_order\_by} \; \mt{tables} \; \mt{exps} \to \mt{sql\_order\_by} \; \mt{tables} \; \mt{exps} \\ + \mt{val} \; \mt{sql\_order\_by\_random} : \mt{tables} ::: \{\{\mt{Type}\}\} \to \mt{exps} ::: \{\mt{Type}\} \to \mt{sql\_order\_by} \; \mt{tables} \; \mt{exps} \\ \\ \mt{type} \; \mt{sql\_limit} \\ \mt{val} \; \mt{sql\_no\_limit} : \mt{sql\_limit} \\ @@ -2125,10 +2126,11 @@ Queries $Q$ are added to the rules for expressions $e$. $$\begin{array}{rrcll} - \textrm{Queries} & Q &::=& (q \; [\mt{ORDER} \; \mt{BY} \; (E \; [o],)^+] \; [\mt{LIMIT} \; N] \; [\mt{OFFSET} \; N]) \\ + \textrm{Queries} & Q &::=& (q \; [\mt{ORDER} \; \mt{BY} \; O] \; [\mt{LIMIT} \; N] \; [\mt{OFFSET} \; N]) \\ \textrm{Pre-queries} & q &::=& \mt{SELECT} \; [\mt{DISTINCT}] \; P \; \mt{FROM} \; F,^+ \; [\mt{WHERE} \; E] \; [\mt{GROUP} \; \mt{BY} \; p,^+] \; [\mt{HAVING} \; E] \\ &&& \mid q \; R \; q \mid \{\{\{e\}\}\} \\ - \textrm{Relational operators} & R &::=& \mt{UNION} \mid \mt{INTERSECT} \mid \mt{EXCEPT} + \textrm{Relational operators} & R &::=& \mt{UNION} \mid \mt{INTERSECT} \mid \mt{EXCEPT} \\ + \textrm{$\mt{ORDER \; BY}$ items} & O &::=& \mt{RANDOM} [()] \mid E \; [o] \mid E \; [o], O \end{array}$$ $$\begin{array}{rrcll} diff -r be1ed46d73e2 -r 9dd8d47c3e58 src/urweb.grm --- a/src/urweb.grm Fri Feb 03 08:30:56 2012 -0500 +++ b/src/urweb.grm Sat Feb 04 10:42:18 2012 -0500 @@ -2039,6 +2039,7 @@ popt : () | LPAREN RPAREN () + | UNIT () diropt : (EVar (["Basis"], "sql_asc", Infer), dummy) | ASC (EVar (["Basis"], "sql_asc", Infer), s (ASCleft, ASCright))