grammar.html 6.2 KB
Newer Older
1 2
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<!--
3
Copyright 2004-2014 H2 Group. Multiple-Licensed under the MPL 2.0, Version 1.0,
4 5 6 7
and under the Eclipse Public License, Version 1.0
Initial Developer: H2 Group
-->
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
8
<head><meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
Thomas Mueller's avatar
Thomas Mueller committed
9
<meta name="viewport" content="width=device-width, initial-scale=1" />
10
<title>
11
SQL Grammar
12 13
</title>
<link rel="stylesheet" type="text/css" href="stylesheet.css" />
14 15 16 17 18 19 20
<!-- [search] { -->
<script type="text/javascript" src="navigation.js"></script>
</head><body onload="frameMe();">
<table class="content"><tr class="content"><td class="content"><div class="contentDiv">
<!-- } -->

<h1>SQL Grammar</h1>
Thomas Mueller's avatar
Thomas Mueller committed
21 22
<h2>Index</h2>
<h3>Commands (Data Manipulation)</h3>
23
<!-- syntax-start
24
<p class="notranslate">
25 26 27
<c:forEach var="item" items="commandsDML">
    <a href="#${item.link}">${item.topic}</a><br />
</c:forEach>
28
</p>
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48
syntax-end -->
<!-- railroad-start -->
<table class="notranslate index">
    <tr>
        <td class="index">
            <c:forEach var="item" items="commandsDML-0">
                <a href="#${item.link}" >${item.topic}</a><br />
            </c:forEach>
        </td><td class="index">
            <c:forEach var="item" items="commandsDML-1">
                <a href="#${item.link}" >${item.topic}</a><br />
            </c:forEach>
        </td><td class="index">
            <c:forEach var="item" items="commandsDML-2">
                <a href="#${item.link}" >${item.topic}</a><br />
            </c:forEach>
        </td>
    </tr>
</table>
<!-- railroad-end -->
49

Thomas Mueller's avatar
Thomas Mueller committed
50
<h3>Commands (Data Definition)</h3>
51
<!-- syntax-start
52
<p class="notranslate">
53 54 55
<c:forEach var="item" items="commandsDDL">
    <a href="#${item.link}">${item.topic}</a><br />
</c:forEach>
56
</p>
57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
syntax-end -->
<!-- railroad-start -->
<table class="notranslate index">
    <tr>
        <td class="index">
            <c:forEach var="item" items="commandsDDL-0">
                <a href="#${item.link}" >${item.topic}</a><br />
            </c:forEach>
        </td><td class="index">
            <c:forEach var="item" items="commandsDDL-1">
                <a href="#${item.link}" >${item.topic}</a><br />
            </c:forEach>
        </td><td class="index">
            <c:forEach var="item" items="commandsDDL-2">
                <a href="#${item.link}" >${item.topic}</a><br />
            </c:forEach>
        </td>
    </tr>
</table>
<!-- railroad-end -->
77

Thomas Mueller's avatar
Thomas Mueller committed
78
<h3>Commands (Other)</h3>
79
<!-- syntax-start
80
<p class="notranslate">
81 82 83
<c:forEach var="item" items="commandsOther">
    <a href="#${item.link}">${item.topic}</a><br />
</c:forEach>
84
</p>
85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
syntax-end -->
<!-- railroad-start -->
<table class="notranslate index">
    <tr>
        <td class="index">
            <c:forEach var="item" items="commandsOther-0">
                <a href="#${item.link}" >${item.topic}</a><br />
            </c:forEach>
        </td><td class="index">
            <c:forEach var="item" items="commandsOther-1">
                <a href="#${item.link}" >${item.topic}</a><br />
            </c:forEach>
        </td><td class="index">
            <c:forEach var="item" items="commandsOther-2">
                <a href="#${item.link}" >${item.topic}</a><br />
            </c:forEach>
        </td>
    </tr>
</table>
<!-- railroad-end -->
105

Thomas Mueller's avatar
Thomas Mueller committed
106
<h3>Other Grammar</h3>
107
<!-- syntax-start
108
<p class="notranslate">
109
<c:forEach var="item" items="otherGrammar">
110
    <a href="#${item.link}" >${item.topic}</a><br />
111
</c:forEach>
112
</p>
113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132
syntax-end -->
<!-- railroad-start -->
<table class="notranslate index">
    <tr>
        <td class="index">
            <c:forEach var="item" items="otherGrammar-0">
                <a href="#${item.link}" >${item.topic}</a><br />
            </c:forEach>
        </td><td class="index">
            <c:forEach var="item" items="otherGrammar-1">
                <a href="#${item.link}" >${item.topic}</a><br />
            </c:forEach>
        </td><td class="index">
            <c:forEach var="item" items="otherGrammar-2">
                <a href="#${item.link}" >${item.topic}</a><br />
            </c:forEach>
        </td>
    </tr>
</table>
<!-- railroad-end -->
133

Thomas Mueller's avatar
Thomas Mueller committed
134
<h3>System Tables</h3>
135
<p class="notranslate">
136 137
<a href="#information_schema">Information Schema</a><br />
<a href="#range_table">Range Table</a><br />
138
</p>
139

Thomas Mueller's avatar
Thomas Mueller committed
140 141 142 143 144
<!-- railroad-start -->
<h2>Details</h2>
<p>Click on the header to switch between railroad diagram and BNF.</p>
<!-- railroad-end -->

145
<c:forEach var="item" items="commands">
Thomas Mueller's avatar
Thomas Mueller committed
146
<h3 id="${item.link}" class="notranslate" onclick="switchBnf(this)">${item.topic}</h3>
147
<!-- railroad-start -->
Thomas Mueller's avatar
Thomas Mueller committed
148 149 150 151
<pre name="bnf" style="display: none">
${item.syntax}
</pre>
<div name="railroad">
152
${item.railroad}
Thomas Mueller's avatar
Thomas Mueller committed
153
</div>
154 155
<!-- railroad-end -->
<!-- syntax-start
156
<pre>
157 158
${item.syntax}
</pre>
159
syntax-end -->
160
<p>${item.text}</p>
161 162 163
<p>Example:</p>
<p class="notranslate">
${item.example}</p>
164 165 166
</c:forEach>

<c:forEach var="item" items="otherGrammar">
Thomas Mueller's avatar
Thomas Mueller committed
167
<h3 id="${item.link}" class="notranslate" onclick="switchBnf(this)">${item.topic}</h3>
168 169 170 171
<!-- railroad-start -->
${item.railroad}
<!-- railroad-end -->
<!-- syntax-start
172
<pre>
173 174
${item.syntax}
</pre>
175
syntax-end -->
176
<p>${item.text}</p>
177
<p>Example:</p>
178
<p class="notranslate">${item.example}</p>
179 180
</c:forEach>

181
<h3 id="information_schema" class="notranslate">Information Schema</h3>
182
<p>
183
The system tables in the schema <code>INFORMATION_SCHEMA</code> contain the meta data
184 185
of all tables in the database as well as the current settings.
</p>
186 187
<table class="main">
<tr><th>Table</th><th>Columns</th></tr>
188
<c:forEach var="item" items="informationSchema">
189 190 191 192
<tr class="notranslate">
    <td>${item.topic}</td>
    <td>${item.syntax}</td>
</tr>
193 194 195
</c:forEach>
</table>

196
<h3 id="range_table" class="notranslate">Range Table</h3>
197 198 199 200 201
<p>
The range table is a dynamic system table that contains all values from a start to an end value.
The table contains one column called X. Both the start and end values are included in the result.
The table is used as follows:
</p>
202
<p>Example:</p>
203
<pre>
204 205 206
SELECT X FROM SYSTEM_RANGE(1, 10);
</pre>

Thomas Mueller's avatar
Thomas Mueller committed
207 208
<!--[if lte IE 7]><script language="javascript">switchBnf(null);</script><![endif]-->

209
<!-- [close] { --></div></td></tr></table><!-- } --><!-- analytics --></body></html>