aboutsummaryrefslogtreecommitdiff
path: root/samples/select-from.ebnf
blob: 5ace952d81f33cbc4d3a09b9f39095c4f514f201 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
.EBNF
###
### SQL SELECT FROM statement
###

%linewid = linewid/2;
%boxwid = boxwid*1.3;
%boxht = boxht*0.8;
%circlerad = boxht/2;

`\f[BI]SELECT\fP`~Statement = `\fBSELECT\fP`, ("*" | {Derived~Column}~","),
                              Table;
Derived~Column = Scalar~Expression, [`\fBAS\fP`, Column~Name];

Table = `\fBFROM\fP`, {Table~Name}~",",
        [`\f[BI]WHERE\fP`~Clause],
        [`\f[BI]GROUP BY\fP`~Clause],
        [`\f[BI]ORDER BY\fP`~Clause];

`\f[BI]WHERE\fP`~Clause = `\fBWHERE\fP`, Condition;

`\f[BI]GROUP BY\fP`~Clause = `\fBGROUP\fP`, `\fBBY\fP`,
                             {Column~Name}~",";

`\f[BI]ORDER BY\fP`~Clause = `\fBORDER\fP`, `\fBBY\fP`, {
                                Column~Name,
                                [`\fBASCENDING\fP` | `\fBDESCENDING\fP`]
                              }~",";
.EBNF