blob: 16116d5f2897321fa145a8eced69b7a4dd397ff7 [file] [log] [blame]
Ian Maxonb2f1d3e2018-10-12 14:42:34 -07001<!DOCTYPE html>
2<!--
Ian Maxon41b806c2019-03-07 15:58:20 -08003 | Generated by Apache Maven Doxia Site Renderer 1.8.1 from target/generated-site/markdown/datamodel.md at 2019-03-07
Ian Maxonb2f1d3e2018-10-12 14:42:34 -07004 | Rendered using Apache Maven Fluido Skin 1.7
5-->
6<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
7 <head>
8 <meta charset="UTF-8" />
9 <meta name="viewport" content="width=device-width, initial-scale=1.0" />
Ian Maxon41b806c2019-03-07 15:58:20 -080010 <meta name="Date-Revision-yyyymmdd" content="20190307" />
Ian Maxonb2f1d3e2018-10-12 14:42:34 -070011 <meta http-equiv="Content-Language" content="en" />
12 <title>AsterixDB &#x2013; The Asterix Data Model (ADM)</title>
13 <link rel="stylesheet" href="./css/apache-maven-fluido-1.7.min.css" />
14 <link rel="stylesheet" href="./css/site.css" />
15 <link rel="stylesheet" href="./css/print.css" media="print" />
16 <script type="text/javascript" src="./js/apache-maven-fluido-1.7.min.js"></script>
17
18 </head>
19 <body class="topBarDisabled">
20 <div class="container-fluid">
21 <div id="banner">
22 <div class="pull-left"><a href="./" id="bannerLeft"><img src="images/asterixlogo.png" alt="AsterixDB"/></a></div>
23 <div class="pull-right"></div>
24 <div class="clear"><hr/></div>
25 </div>
26
27 <div id="breadcrumbs">
28 <ul class="breadcrumb">
Ian Maxon41b806c2019-03-07 15:58:20 -080029 <li id="publishDate">Last Published: 2019-03-07</li>
Ian Maxonb2f1d3e2018-10-12 14:42:34 -070030 <li id="projectVersion" class="pull-right">Version: 0.9.4</li>
31 <li class="pull-right"><a href="index.html" title="Documentation Home">Documentation Home</a></li>
32 </ul>
33 </div>
34 <div class="row-fluid">
35 <div id="leftColumn" class="span2">
36 <div class="well sidebar-nav">
37 <ul class="nav nav-list">
38 <li class="nav-header">Get Started - Installation</li>
39 <li><a href="ncservice.html" title="Option 1: using NCService"><span class="none"></span>Option 1: using NCService</a></li>
40 <li><a href="ansible.html" title="Option 2: using Ansible"><span class="none"></span>Option 2: using Ansible</a></li>
41 <li><a href="aws.html" title="Option 3: using Amazon Web Services"><span class="none"></span>Option 3: using Amazon Web Services</a></li>
42 <li class="nav-header">AsterixDB Primer</li>
Ian Maxon41b806c2019-03-07 15:58:20 -080043 <li><a href="sqlpp/primer-sqlpp.html" title="Option 1: using SQL++"><span class="none"></span>Option 1: using SQL++</a></li>
44 <li><a href="aql/primer.html" title="Option 2: using AQL"><span class="none"></span>Option 2: using AQL</a></li>
Ian Maxonb2f1d3e2018-10-12 14:42:34 -070045 <li class="nav-header">Data Model</li>
46 <li class="active"><a href="#"><span class="none"></span>The Asterix Data Model</a></li>
Ian Maxon41b806c2019-03-07 15:58:20 -080047 <li class="nav-header">Queries - SQL++</li>
Ian Maxonb2f1d3e2018-10-12 14:42:34 -070048 <li><a href="sqlpp/manual.html" title="The SQL++ Query Language"><span class="none"></span>The SQL++ Query Language</a></li>
49 <li><a href="sqlpp/builtins.html" title="Builtin Functions"><span class="none"></span>Builtin Functions</a></li>
Ian Maxon41b806c2019-03-07 15:58:20 -080050 <li class="nav-header">Queries - AQL</li>
51 <li><a href="aql/manual.html" title="The Asterix Query Language (AQL)"><span class="none"></span>The Asterix Query Language (AQL)</a></li>
52 <li><a href="aql/builtins.html" title="Builtin Functions"><span class="none"></span>Builtin Functions</a></li>
Ian Maxonb2f1d3e2018-10-12 14:42:34 -070053 <li class="nav-header">API/SDK</li>
54 <li><a href="api.html" title="HTTP API"><span class="none"></span>HTTP API</a></li>
55 <li><a href="csv.html" title="CSV Output"><span class="none"></span>CSV Output</a></li>
56 <li class="nav-header">Advanced Features</li>
Ian Maxon41b806c2019-03-07 15:58:20 -080057 <li><a href="aql/fulltext.html" title="Support of Full-text Queries"><span class="none"></span>Support of Full-text Queries</a></li>
Ian Maxonb2f1d3e2018-10-12 14:42:34 -070058 <li><a href="aql/externaldata.html" title="Accessing External Data"><span class="none"></span>Accessing External Data</a></li>
Ian Maxon41b806c2019-03-07 15:58:20 -080059 <li><a href="feeds/tutorial.html" title="Support for Data Ingestion"><span class="none"></span>Support for Data Ingestion</a></li>
Ian Maxonb2f1d3e2018-10-12 14:42:34 -070060 <li><a href="udf.html" title="User Defined Functions"><span class="none"></span>User Defined Functions</a></li>
Ian Maxon41b806c2019-03-07 15:58:20 -080061 <li><a href="aql/filters.html" title="Filter-Based LSM Index Acceleration"><span class="none"></span>Filter-Based LSM Index Acceleration</a></li>
62 <li><a href="aql/similarity.html" title="Support of Similarity Queries"><span class="none"></span>Support of Similarity Queries</a></li>
Ian Maxonb2f1d3e2018-10-12 14:42:34 -070063</ul>
64 <hr />
65 <div id="poweredBy">
66 <div class="clear"></div>
67 <div class="clear"></div>
68 <div class="clear"></div>
69 <div class="clear"></div>
70<a href="./" title="AsterixDB" class="builtBy"><img class="builtBy" alt="AsterixDB" src="images/asterixlogo.png" /></a>
71 </div>
72 </div>
73 </div>
74 <div id="bodyColumn" class="span10" >
75<!--
76 ! Licensed to the Apache Software Foundation (ASF) under one
77 ! or more contributor license agreements. See the NOTICE file
78 ! distributed with this work for additional information
79 ! regarding copyright ownership. The ASF licenses this file
80 ! to you under the Apache License, Version 2.0 (the
81 ! "License"); you may not use this file except in compliance
82 ! with the License. You may obtain a copy of the License at
83 !
84 ! http://www.apache.org/licenses/LICENSE-2.0
85 !
86 ! Unless required by applicable law or agreed to in writing,
87 ! software distributed under the License is distributed on an
88 ! "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
89 ! KIND, either express or implied. See the License for the
90 ! specific language governing permissions and limitations
91 ! under the License.
92 !-->
93<h1>The Asterix Data Model (ADM)</h1>
94<div class="section">
95<h2><a name="Table_of_Contents"></a><a name="toc" id="toc">Table of Contents</a></h2>
96<ul>
97
98<li><a href="#PrimitiveTypes">Primitive Types</a>
99<ul>
100
101<li><a href="#PrimitiveTypesBoolean">Boolean</a></li>
102<li><a href="#PrimitiveTypesString">String</a></li>
103<li><a href="#PrimitiveTypesInt">Tinyint / Smallint / Integer (Int) / Bigint</a></li>
104<li><a href="#PrimitiveTypesFloat">Float</a></li>
105<li><a href="#PrimitiveTypesDouble">Double (Double Precision)</a></li>
106<li><a href="#PrimitiveTypesBinary">Binary</a></li>
107<li><a href="#PrimitiveTypesPoint">Point</a></li>
108<li><a href="#PrimitiveTypesLine">Line</a></li>
109<li><a href="#PrimitiveTypesRectangle">Rectangle</a></li>
110<li><a href="#PrimitiveTypesCircle">Circle</a></li>
111<li><a href="#PrimitiveTypesPolygon">Polygon</a></li>
112<li><a href="#PrimitiveTypesDate">Date</a></li>
113<li><a href="#PrimitiveTypesTime">Time</a></li>
114<li><a href="#PrimitiveTypesDateTime">Datetime (Timestamp)</a></li>
115<li><a href="#PrimitiveTypesDuration">Duration/Year_month_duration/Day_time_duration</a></li>
116<li><a href="#PrimitiveTypesInterval">Interval</a></li>
117<li><a href="#PrimitiveTypesUUID">UUID</a></li>
118</ul>
119</li>
120<li>[Incomplete Information Types] (#IncompleteInformationTypes)
121<ul>
122
123<li><a href="#IncompleteInformationTypesNull">Null</a></li>
124<li><a href="#IncompleteInformationTypesMissing">Missing</a></li>
125</ul>
126</li>
127<li><a href="#DerivedTypes">Derived Types</a>
128<ul>
129
130<li><a href="#DerivedTypesObject">Object</a></li>
131<li><a href="#DerivedTypesArray">Array</a></li>
132<li><a href="#DerivedTypesMultiset">Multiset</a></li>
133</ul>
134</li>
135</ul>
136<p>An instance of Asterix data model (ADM) can be a <i><i>primitive type</i></i> (<tt>boolean</tt>, <tt>tinyint</tt>, <tt>smallint</tt>, <tt>integer</tt>, <tt>bigint</tt>, <tt>string</tt>, <tt>float</tt>, <tt>double</tt>, <tt>date</tt>, <tt>time</tt>, <tt>datetime</tt>, etc.), a <i><i>special type</i></i> (<tt>null</tt> or <tt>missing</tt>), or a <i><i>derived type</i></i>.</p>
137<p>The type names are case-insensitive, e.g., both <tt>BIGINT</tt> and <tt>bigint</tt> are acceptable.</p><!--
138 ! Licensed to the Apache Software Foundation (ASF) under one
139 ! or more contributor license agreements. See the NOTICE file
140 ! distributed with this work for additional information
141 ! regarding copyright ownership. The ASF licenses this file
142 ! to you under the Apache License, Version 2.0 (the
143 ! "License"); you may not use this file except in compliance
144 ! with the License. You may obtain a copy of the License at
145 !
146 ! http://www.apache.org/licenses/LICENSE-2.0
147 !
148 ! Unless required by applicable law or agreed to in writing,
149 ! software distributed under the License is distributed on an
150 ! "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
151 ! KIND, either express or implied. See the License for the
152 ! specific language governing permissions and limitations
153 ! under the License.
154 !-->
155</div>
156<div class="section">
157<h2><a name="Primitive_Types"></a><a name="PrimitiveTypes" id="PrimitiveTypes">Primitive Types</a></h2>
158<div class="section">
159<h3><a name="Boolean"></a><a name="PrimitiveTypesBoolean" id="PrimitiveTypesBoolean">Boolean</a></h3>
160<p><tt>boolean</tt> data type can have one of the two values: <i><i>true</i></i> or <i><i>false</i></i>.</p>
161<ul>
162
163<li>
164
165<p>Example:</p>
166
167<div>
168<div>
169<pre class="source">{ &quot;true&quot;: true, &quot;false&quot;: false };
170</pre></div></div>
171</li>
172<li>
173
174<p>The expected result is:</p>
175
176<div>
177<div>
178<pre class="source">{ &quot;true&quot;: true, &quot;false&quot;: false }
179</pre></div></div>
180</li>
181</ul></div>
182<div class="section">
183<h3><a name="String"></a><a name="PrimitiveTypesString" id="PrimitiveTypesString">String</a></h3>
184<p><tt>string</tt> represents a sequence of characters. The total length of the sequence can be up to 2,147,483,648.</p>
185<ul>
186
187<li>
188
189<p>Example:</p>
190
191<div>
192<div>
193<pre class="source">{ &quot;v1&quot;: string(&quot;This is a string.&quot;), &quot;v2&quot;: string(&quot;\&quot;This is a quoted string\&quot;&quot;) };
194</pre></div></div>
195</li>
196<li>
197
198<p>The expected result is:</p>
199
200<div>
201<div>
202<pre class="source">{ &quot;v1&quot;: &quot;This is a string.&quot;, &quot;v2&quot;: &quot;\&quot;This is a quoted string\&quot;&quot; }
203</pre></div></div>
204</li>
205</ul><!--
206 ! Licensed to the Apache Software Foundation (ASF) under one
207 ! or more contributor license agreements. See the NOTICE file
208 ! distributed with this work for additional information
209 ! regarding copyright ownership. The ASF licenses this file
210 ! to you under the Apache License, Version 2.0 (the
211 ! "License"); you may not use this file except in compliance
212 ! with the License. You may obtain a copy of the License at
213 !
214 ! http://www.apache.org/licenses/LICENSE-2.0
215 !
216 ! Unless required by applicable law or agreed to in writing,
217 ! software distributed under the License is distributed on an
218 ! "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
219 ! KIND, either express or implied. See the License for the
220 ! specific language governing permissions and limitations
221 ! under the License.
222 !-->
223</div>
224<div class="section">
225<h3><a name="Tinyint_.2F_Smallint_.2F_Integer_.28Int.29_.2F_Bigint"></a><a name="PrimitiveTypesInt" id="PrimitiveTypesInt">Tinyint / Smallint / Integer (Int) / Bigint</a></h3>
226<p>Integer types using 8, 16, 32, or 64 bits. The ranges of these types are:</p>
227<ul>
228
229<li><tt>tinyint</tt>: -128 to 127</li>
230<li><tt>smallint</tt>: -32768 to 32767</li>
231<li><tt>integer</tt>: -2147483648 to 2147483647</li>
232<li><tt>bigint</tt>: -9223372036854775808 to 9223372036854775807</li>
233</ul>
234<p><tt>int</tt> is an abbreviated alias for integer.</p>
235<ul>
236
237<li>
238
239<p>Example:</p>
240
241<div>
242<div>
243<pre class="source">{ &quot;tinyint&quot;: tiny(&quot;125&quot;), &quot;smallint&quot;: smallint(&quot;32765&quot;), &quot;integer&quot;: 294967295, &quot;bigint&quot;: bigint(&quot;1700000000000000000&quot;)};
244</pre></div></div>
245</li>
246<li>
247
248<p>The expected result is:</p>
249
250<div>
251<div>
252<pre class="source">{ &quot;tinyint&quot;: 125, &quot;smallint&quot;: 32765, &quot;integer&quot;: 294967295, &quot;bigint&quot;: 1700000000000000000 }
253</pre></div></div>
254</li>
255</ul></div>
256<div class="section">
257<h3><a name="Float"></a><a name="PrimitiveTypesFloat" id="PrimitiveTypesFloat">Float</a></h3>
258<p><tt>float</tt> represents approximate numeric data values using 4 bytes. The range of a float value can be from 2^(-149) to (2-2^(-23)&#xb7;2^(127) for both positive and negative. Beyond these ranges will get <tt>INF</tt> or <tt>-INF</tt>.</p>
259<ul>
260
261<li>
262
263<p>Example:</p>
264
265<div>
266<div>
267<pre class="source">{ &quot;v1&quot;: float(&quot;NaN&quot;), &quot;v2&quot;: float(&quot;INF&quot;), &quot;v3&quot;: float(&quot;-INF&quot;), &quot;v4&quot;: float(&quot;-2013.5&quot;) };
268</pre></div></div>
269</li>
270<li>
271
272<p>The expected result is:</p>
273
274<div>
275<div>
276<pre class="source">{ &quot;v1&quot;: &quot;NaN&quot;, &quot;v2&quot;: &quot;INF&quot;, &quot;v3&quot;: &quot;-INF&quot;, &quot;v4&quot;: -2013.5 }
277</pre></div></div>
278</li>
279</ul></div>
280<div class="section">
281<h3><a name="Double_.28double_precision.29"></a><a name="PrimitiveTypesDouble" id="PrimitiveTypesDouble">Double (double precision)</a></h3>
282<p><tt>double</tt> represents approximate numeric data values using 8 bytes. The range of a double value can be from (2^(-1022)) to (2-2^(-52))&#xb7;2^(1023) for both positive and negative. Beyond these ranges will get <tt>INF</tt> or <tt>-INF</tt>.</p>
283<ul>
284
285<li>
286
287<p>Example:</p>
288
289<div>
290<div>
291<pre class="source">{ &quot;v1&quot;: double(&quot;NaN&quot;), &quot;v2&quot;: double(&quot;INF&quot;), &quot;v3&quot;: double(&quot;-INF&quot;), &quot;v4&quot;: &quot;-2013.593823748327284&quot; };
292</pre></div></div>
293</li>
294<li>
295
296<p>The expected result is:</p>
297
298<div>
299<div>
300<pre class="source">{ &quot;v1&quot;: &quot;NaN&quot;, &quot;v2&quot;: &quot;INF&quot;, &quot;v3&quot;: &quot;-INF&quot;, &quot;v4&quot;: -2013.5938237483274 }
301</pre></div></div>
302</li>
303</ul>
304<p><tt>Double precision</tt> is an alias of <tt>double</tt>.</p></div>
305<div class="section">
306<h3><a name="Binary"></a><a name="PrimitiveTypesBinary" id="PrimitiveTypesBinary">Binary</a></h3>
307<p><tt>binary</tt> represents a sequence of bytes. It can be constructed from a <tt>hex</tt> or a <tt>base64</tt> string sequence. The total length of the byte sequence can be up to 2,147,483,648.</p>
308<ul>
309
310<li>
311
312<p>Example:</p>
313
314<div>
315<div>
316<pre class="source">{
317 &quot;hex1&quot; : hex(&quot;ABCDEF0123456789&quot;),
318 &quot;hex2&quot;: hex(&quot;abcdef0123456789&quot;),
319 &quot;base64_1&quot; : base64(&quot;0123456789qwertyui+/&quot;),
320 &quot;base64_2&quot; : base64('QXN0ZXJpeA==')
321};
322</pre></div></div>
323</li>
324<li>
325
326<p>The default output format is in <tt>hex</tt> format. Thus, the expected result is:</p>
327
328<div>
329<div>
330<pre class="source">{
331 &quot;hex1&quot;: hex(&quot;ABCDEF0123456789&quot;),
332 &quot;hex2&quot;: hex(&quot;ABCDEF0123456789&quot;),
333 &quot;base64_1&quot;: hex(&quot;D35DB7E39EBBF3DAB07ABB72BA2FBF&quot;),
334 &quot;base64_2&quot;: hex(&quot;41737465726978&quot;)
335}
336</pre></div></div>
337</li>
338</ul></div>
339<div class="section">
340<h3><a name="Point"></a><a name="PrimitiveTypesPoint" id="PrimitiveTypesPoint">Point</a></h3>
341<p><tt>point</tt> is the fundamental two-dimensional building block for spatial types. It consists of two <tt>double</tt> coordinates x and y.</p>
342<ul>
343
344<li>
345
346<p>Example:</p>
347
348<div>
349<div>
350<pre class="source">{ &quot;v1&quot;: point(&quot;80.10d, -10E5&quot;), &quot;v2&quot;: point(&quot;5.10E-10d, -10E5&quot;) };
351</pre></div></div>
352</li>
353<li>
354
355<p>The expected result is:</p>
356
357<div>
358<div>
359<pre class="source">{ &quot;v1&quot;: point(&quot;80.1,-1000000.0&quot;), &quot;v2&quot;: point(&quot;5.1E-10,-1000000.0&quot;) }
360</pre></div></div>
361</li>
362</ul></div>
363<div class="section">
364<h3><a name="Line"></a><a name="PrimitiveTypesLine" id="PrimitiveTypesLine">Line</a></h3>
365<p><tt>line</tt> consists of two points that represent the start and the end points of a line segment.</p>
366<ul>
367
368<li>
369
370<p>Example:</p>
371
372<div>
373<div>
374<pre class="source">{ &quot;v1&quot;: line(&quot;10.1234,11.1e-1 +10.2E-2,-11.22&quot;), &quot;v2&quot;: line(&quot;0.1234,-1.00e-10 +10.5E-2,-01.02&quot;) };
375</pre></div></div>
376</li>
377<li>
378
379<p>The expected result is:</p>
380
381<div>
382<div>
383<pre class="source">{ &quot;v1&quot;: line(&quot;10.1234,1.11 0.102,-11.22&quot;), &quot;v2&quot;: line(&quot;0.1234,-1.0E-10 0.105,-1.02&quot;) }
384</pre></div></div>
385</li>
386</ul></div>
387<div class="section">
388<h3><a name="Rectangle"></a><a name="PrimitiveTypesRectangle" id="PrimitiveTypesRectangle">Rectangle</a></h3>
389<p><tt>rectangle</tt> consists of two points that represent the <i><i>bottom left</i></i> and <i><i>upper right</i></i> corners of a rectangle.</p>
390<ul>
391
392<li>
393
394<p>Example:</p>
395
396<div>
397<div>
398<pre class="source">{ &quot;v1&quot;: rectangle(&quot;5.1,11.8 87.6,15.6548&quot;), &quot;v2&quot;: rectangle(&quot;0.1234,-1.00e-10 5.5487,0.48765&quot;) };
399</pre></div></div>
400</li>
401<li>
402
403<p>The expected result is:</p>
404
405<div>
406<div>
407<pre class="source">{ &quot;v1&quot;: rectangle(&quot;5.1,11.8 87.6,15.6548&quot;), &quot;v2&quot;: rectangle(&quot;0.1234,-1.0E-10 5.5487,0.48765&quot;) }
408</pre></div></div>
409</li>
410</ul></div>
411<div class="section">
412<h3><a name="Circle"></a><a name="PrimitiveTypesCircle" id="PrimitiveTypesCircle">Circle</a></h3>
413<p><tt>circle</tt> consists of one point that represents the center of the circle and a radius of type <tt>double</tt>.</p>
414<ul>
415
416<li>
417
418<p>Example:</p>
419
420<div>
421<div>
422<pre class="source">{ &quot;v1&quot;: circle(&quot;10.1234,11.1e-1 +10.2E-2&quot;), &quot;v2&quot;: circle(&quot;0.1234,-1.00e-10 +10.5E-2&quot;) };
423</pre></div></div>
424</li>
425<li>
426
427<p>The expected result is:</p>
428
429<div>
430<div>
431<pre class="source">{ &quot;v1&quot;: circle(&quot;10.1234,1.11 0.102&quot;), &quot;v2&quot;: circle(&quot;0.1234,-1.0E-10 0.105&quot;) }
432</pre></div></div>
433</li>
434</ul></div>
435<div class="section">
436<h3><a name="Polygon"></a><a name="PrimitiveTypesPolygon" id="PrimitiveTypesPolygon">Polygon</a></h3>
437<p><tt>polygon</tt> consists of <i><i>n</i></i> points that represent the vertices of a <i><i>simple closed</i></i> polygon.</p>
438<ul>
439
440<li>
441
442<p>Example:</p>
443
444<div>
445<div>
446<pre class="source">{
447 &quot;v1&quot;: polygon(&quot;-1.2,+1.3e2 -2.14E+5,2.15 -3.5e+2,03.6 -4.6E-3,+4.81&quot;),
448 &quot;v2&quot;: polygon(&quot;-1.0,+10.5e2 -02.15E+50,2.5 -1.0,+3.3e3 -2.50E+05,20.15 +3.5e+2,03.6 -4.60E-3,+4.75 -2,+1.0e2 -2.00E+5,20.10 30.5,03.25 -4.33E-3,+4.75&quot;)
449};
450</pre></div></div>
451</li>
452<li>
453
454<p>The expected result is:</p>
455
456<div>
457<div>
458<pre class="source">{
459 &quot;v1&quot;: polygon(&quot;-1.2,130.0 -214000.0,2.15 -350.0,3.6 -0.0046,4.81&quot;),
460 &quot;v2&quot;: polygon(&quot;-1.0,1050.0 -2.15E50,2.5 -1.0,3300.0 -250000.0,20.15 350.0,3.6 -0.0046,4.75 -2.0,100.0 -200000.0,20.1 30.5,3.25 -0.00433,4.75&quot;) }
461}
462</pre></div></div>
463</li>
464</ul></div>
465<div class="section">
466<h3><a name="Date"></a><a name="PrimitiveTypesDate" id="PrimitiveTypesDate">Date</a></h3>
467<p><tt>date</tt> represents a time point along the Gregorian calendar system specified by the year, month and day. ASTERIX supports the date from <tt>-9999-01-01</tt> to <tt>9999-12-31</tt>.</p>
468<p>A date value can be represented in two formats, extended format and basic format.</p>
469<ul>
470
471<li>Extended format is represented as <tt>[-]yyyy-mm-dd</tt> for <tt>year-month-day</tt>. Each field should be padded if there are less digits than the format specified.</li>
472<li>Basic format is in the format of <tt>[-]yyyymmdd</tt>.</li>
473<li>
474
475<p>Example:</p>
476
477<div>
478<div>
479<pre class="source">{ &quot;v1&quot;: date(&quot;2013-01-01&quot;), &quot;v2&quot;: date(&quot;-19700101&quot;) };
480</pre></div></div>
481</li>
482<li>
483
484<p>The expected result is:</p>
485
486<div>
487<div>
488<pre class="source">{ &quot;v1&quot;: date(&quot;2013-01-01&quot;), &quot;v2&quot;: date(&quot;-1970-01-01&quot;) }
489</pre></div></div>
490</li>
491</ul></div>
492<div class="section">
493<h3><a name="Time"></a><a name="PrimitiveTypesTime" id="PrimitiveTypesTime">Time</a></h3>
494<p><tt>time</tt> type describes the time within the range of a day. It is represented by three fields: hour, minute and second. Millisecond field is optional as the fraction of the second field. Its extended format is as <tt>hh:mm:ss[.mmm]</tt> and the basic format is <tt>hhmmss[mmm]</tt>. The value domain is from <tt>00:00:00.000</tt> to <tt>23:59:59.999</tt>.</p>
495<p>Timezone field is optional for a time value. Timezone is represented as <tt>[+|-]hh:mm</tt> for extended format or <tt>[+|-]hhmm</tt> for basic format. Note that the sign designators cannot be omitted. <tt>Z</tt> can also be used to represent the UTC local time. If no timezone information is given, it is UTC by default.</p>
496<ul>
497
498<li>
499
500<p>Example:</p>
501
502<div>
503<div>
504<pre class="source">{ &quot;v1&quot;: time(&quot;12:12:12.039Z&quot;), &quot;v2&quot;: time(&quot;000000000-0800&quot;) };
505</pre></div></div>
506</li>
507<li>
508
509<p>The expected result is:</p>
510
511<div>
512<div>
513<pre class="source">{ &quot;v1&quot;: time(&quot;12:12:12.039Z&quot;), &quot;v2&quot;: time(&quot;08:00:00.000Z&quot;) }
514</pre></div></div>
515</li>
516</ul></div>
517<div class="section">
518<h3><a name="Datetime_.28Timestamp.29"></a><a name="PrimitiveTypesDateTime" id="PrimitiveTypesDateTime">Datetime (Timestamp)</a></h3>
519<p>A <tt>datetime</tt> value is a combination of an <tt>date</tt> and <tt>time</tt>, representing a fixed time point along the Gregorian calendar system. The value is among <tt>-9999-01-01 00:00:00.000</tt> and <tt>9999-12-31 23:59:59.999</tt>.</p>
520<p>A <tt>datetime</tt> value is represented as a combination of the representation of its <tt>date</tt> part and <tt>time</tt> part, separated by a separator <tt>T</tt>. Either extended or basic format can be used, and the two parts should be the same format.</p>
521<p>Millisecond field and timezone field are optional, as specified in the <tt>time</tt> type.</p>
522<ul>
523
524<li>
525
526<p>Example:</p>
527
528<div>
529<div>
530<pre class="source">{ &quot;v1&quot;: datetime(&quot;2013-01-01T12:12:12.039Z&quot;), &quot;v2&quot;: datetime(&quot;-19700101T000000000-0800&quot;) };
531</pre></div></div>
532</li>
533<li>
534
535<p>The expected result is:</p>
536
537<div>
538<div>
539<pre class="source">{ &quot;v1&quot;: datetime(&quot;2013-01-01T12:12:12.039Z&quot;), &quot;v2&quot;: datetime(&quot;-1970-01-01T08:00:00.000Z&quot;) }
540</pre></div></div>
541</li>
542</ul>
543<p><tt>timestamp</tt> is an alias of <tt>datetime</tt>.</p></div>
544<div class="section">
545<h3><a name="Duration.2FYear_month_duration.2FDay_time_duration"></a><a name="PrimitiveTypesDuration" id="PrimitiveTypesDuration">Duration/Year_month_duration/Day_time_duration</a></h3>
546<p><tt>duration</tt> represents a duration of time. A duration value is specified by integers on at least one of the following fields: year, month, day, hour, minute, second, and millisecond.</p>
547<p>A duration value is in the format of <tt>[-]PnYnMnDTnHnMn.mmmS</tt>. The millisecond part (as the fraction of the second field) is optional, and when no millisecond field is used, the decimal point should also be absent.</p>
548<p>Negative durations are also supported for the arithmetic operations between time instance types (<tt>date</tt>, <tt>time</tt> and <tt>datetime</tt>), and is used to roll the time back for the given duration. For example <tt>date(&quot;2012-01-01&quot;) + duration(&quot;-P3D&quot;)</tt> will return <tt>date(&quot;2011-12-29&quot;)</tt>.</p>
549<p>There are also two sub-duration types, namely <tt>year_month_duration</tt> and <tt>day_time_duration</tt>. <tt>year_month_duration</tt> represents only the years and months of a duration, while <tt>day_time_duration</tt> represents only the day to millisecond fields. Different from the <tt>duration</tt> type, both these two subtypes are totally ordered, so they can be used for comparison and index construction.</p>
550<p>Note that a canonical representation of the duration is always returned, regardless whether the duration is in the canonical representation or not from the user&#x2019;s input. More information about canonical representation can be found from <a class="externalLink" href="http://www.w3.org/TR/xpath-functions/#canonical-dayTimeDuration">XPath dayTimeDuration Canonical Representation</a> and <a class="externalLink" href="http://www.w3.org/TR/xpath-functions/#canonical-yearMonthDuration">yearMonthDuration Canonical Representation</a>.</p>
551<ul>
552
553<li>
554
555<p>Example:</p>
556
557<div>
558<div>
559<pre class="source">{ &quot;v1&quot;: duration(&quot;P100Y12MT12M&quot;), &quot;v2&quot;: duration(&quot;-PT20.943S&quot;) };
560</pre></div></div>
561</li>
562<li>
563
564<p>The expected result is:</p>
565
566<div>
567<div>
568<pre class="source">{ &quot;v1&quot;: duration(&quot;P101YT12M&quot;), &quot;v2&quot;: duration(&quot;-PT20.943S&quot;) }
569</pre></div></div>
570</li>
571</ul></div>
572<div class="section">
573<h3><a name="Interval"></a><a name="PrimitiveTypesInterval" id="PrimitiveTypesInterval">Interval</a></h3>
574<p><tt>interval</tt> represents inclusive-exclusive ranges of time. It is defined by two time point values with the same temporal type(<tt>date</tt>, <tt>time</tt> or <tt>datetime</tt>).</p>
575<ul>
576
577<li>
578
579<p>Example:</p>
580
581<div>
582<div>
583<pre class="source">{
584 &quot;v1&quot;: interval(date(&quot;2013-01-01&quot;), date(&quot;20130505&quot;)),
585 &quot;v2&quot;: interval(time(&quot;00:01:01&quot;), time(&quot;213901049+0800&quot;)),
586 &quot;v3&quot;: interval(datetime(&quot;2013-01-01T00:01:01&quot;), datetime(&quot;20130505T213901049+0800&quot;))
587};
588</pre></div></div>
589</li>
590<li>
591
592<p>The expected result is:</p>
593
594<div>
595<div>
596<pre class="source">{
597 &quot;v1&quot;: interval(date(&quot;2013-01-01&quot;), date(&quot;2013-05-05&quot;)),
598 &quot;v2&quot;: interval(time(&quot;00:01:01.000Z&quot;), time(&quot;13:39:01.049Z&quot;)),
599 &quot;v3&quot;: interval(datetime(&quot;2013-01-01T00:01:01.000Z&quot;), datetime(&quot;2013-05-05T13:39:01.049Z&quot;))
600}
601</pre></div></div>
602</li>
603</ul></div>
604<div class="section">
605<h3><a name="UUID"></a><a name="PrimitiveTypesUUID" id="PrimitiveTypesUUID">UUID</a></h3>
606<p><tt>uuid</tt> represents a UUID value, which stands for Universally unique identifier. It is defined by a canonical format using hexadecimal text with inserted hyphen characters. (E.g.: 5a28ce1e-6a74-4201-9e8f-683256e5706f). This type is generally used to store auto-generated primary key values.</p>
607<ul>
608
609<li>
610
611<p>Example:</p>
612
613<div>
614<div>
615<pre class="source">return { &quot;v1&quot;:uuid(&quot;5c848e5c-6b6a-498f-8452-8847a2957421&quot;) }
616</pre></div></div>
617</li>
618<li>
619
620<p>The expected result is:</p>
621
622<div>
623<div>
624<pre class="source">{ &quot;v1&quot;: uuid(&quot;5c848e5c-6b6a-498f-8452-8847a2957421&quot;) }
625</pre></div></div>
626</li>
627</ul><!--
628 ! Licensed to the Apache Software Foundation (ASF) under one
629 ! or more contributor license agreements. See the NOTICE file
630 ! distributed with this work for additional information
631 ! regarding copyright ownership. The ASF licenses this file
632 ! to you under the Apache License, Version 2.0 (the
633 ! "License"); you may not use this file except in compliance
634 ! with the License. You may obtain a copy of the License at
635 !
636 ! http://www.apache.org/licenses/LICENSE-2.0
637 !
638 ! Unless required by applicable law or agreed to in writing,
639 ! software distributed under the License is distributed on an
640 ! "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
641 ! KIND, either express or implied. See the License for the
642 ! specific language governing permissions and limitations
643 ! under the License.
644 !-->
645</div></div>
646<div class="section">
647<h2><a name="Incomplete_Information_Types"></a><a name="IncompleteInformationTypes" id="IncompleteInformationTypes">Incomplete Information Types</a></h2>
648<div class="section">
649<h3><a name="Null"></a><a name="IncompleteInformationTypesNull" id="IncompleteInformationTypesNull">Null</a></h3>
650<p><tt>null</tt> is a special value that is often used to represent an unknown value. For example, a user might not be able to know the value of a field and let it be <tt>null</tt>.</p>
651<ul>
652
653<li>
654
655<p>Example:</p>
656
657<div>
658<div>
659<pre class="source">{ &quot;field&quot;: null };
660</pre></div></div>
661</li>
662<li>
663
664<p>The expected result is:</p>
665
666<div>
667<div>
668<pre class="source">{ &quot;field&quot;: null }
669</pre></div></div>
670</li>
671</ul></div>
672<div class="section">
673<h3><a name="Missing"></a><a name="IncompleteInformationTypesMissing" id="IncompleteInformationTypesMissing">Missing</a></h3>
674<p><tt>missing</tt> indicates that a name-value pair is missing from an object. If a missing name-value pair is accessed, an empty result value is returned by the query.</p>
675<p>As neither the data model nor the system enforces homogeneity for datasets or collections, items in a dataset or collection can be of heterogeneous types and so a field can be present in one object and <tt>missing</tt> in another.</p>
676<ul>
677
678<li>
679
680<p>Example:</p>
681
682<div>
683<div>
684<pre class="source">{ &quot;field&quot;: missing };
685</pre></div></div>
686</li>
687<li>
688
689<p>The expected result is:</p>
690
691<div>
692<div>
693<pre class="source">{ }
694</pre></div></div>
695</li>
696</ul>
697<p>Since a field with value <tt>missing</tt> means the field is absent, we get an empty object.</p><!--
698 ! Licensed to the Apache Software Foundation (ASF) under one
699 ! or more contributor license agreements. See the NOTICE file
700 ! distributed with this work for additional information
701 ! regarding copyright ownership. The ASF licenses this file
702 ! to you under the Apache License, Version 2.0 (the
703 ! "License"); you may not use this file except in compliance
704 ! with the License. You may obtain a copy of the License at
705 !
706 ! http://www.apache.org/licenses/LICENSE-2.0
707 !
708 ! Unless required by applicable law or agreed to in writing,
709 ! software distributed under the License is distributed on an
710 ! "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
711 ! KIND, either express or implied. See the License for the
712 ! specific language governing permissions and limitations
713 ! under the License.
714 !-->
715</div></div>
716<div class="section">
717<h2><a name="Derived_Types"></a><a name="DerivedTypes" id="DerivedTypes">Derived Types</a></h2>
718<div class="section">
719<h3><a name="Object"></a><a name="DerivedTypesObject" id="DerivedTypesObject">Object</a></h3>
720<p>An <tt>object</tt> contains a set of &#xfb01;elds, where each &#xfb01;eld is described by its name and type. An object type may be defined as either open or closed. Open objects (instances of open object types) are permitted to contain &#xfb01;elds that are not part of the type de&#xfb01;nition, while closed objects do not permit their instances to carry extra fields. An example type definition for an object is:</p>
721
722<div>
723<div>
724<pre class="source"> create type SoldierType as open {
725 name: string?,
726 rank: string,
727 serialno: int
728 };
729</pre></div></div>
730
731<p>Syntactically, object constructors are surrounded by curly braces &#x201c;{&#x2026;}&#x201d;. Some examples of legitimate instances of the above type include:</p>
732
733<div>
734<div>
735<pre class="source"> { &quot;name&quot;: &quot;Joe Blow&quot;, &quot;rank&quot;: &quot;Sergeant&quot;, &quot;serialno&quot;: 1234567 }
736 { &quot;rank&quot;: &quot;Private&quot;, &quot;serialno&quot;: 9876543 }
737 { &quot;name&quot;: &quot;Sally Forth&quot;, &quot;rank&quot;: &quot;Major&quot;, &quot;serialno&quot;: 2345678, &quot;gender&quot;: &quot;F&quot; }
738</pre></div></div>
739
740<p>The first instance has all of the type&#x2019;s prescribed content. The second instance is missing the name field, which is fine because it is optional (due to the ?). The third instance has an extra field; that is fine because the type definition specifies that it is open (which is also true by default, if open is not specified). To more tightly control object content, specifying closed instead of open in the type definition for SoldierType would have made the third example instance an invalid instance of the type.</p></div>
741<div class="section">
742<h3><a name="Array"></a><a name="DerivedTypesArray" id="DerivedTypesArray">Array</a></h3>
743<p>An <tt>array</tt> is a container that holds a fixed number of values. Array constructors are denoted by brackets: &#x201c;[&#x2026;]&#x201d;.</p>
744<p>An example would be</p>
745
746<div>
747<div>
748<pre class="source"> [&quot;alice&quot;, 123, &quot;bob&quot;, null]
749</pre></div></div>
750</div>
751<div class="section">
752<h3><a name="Multiset"></a><a name="DerivedTypesMultiset" id="DerivedTypesMultiset">Multiset</a></h3>
753<p>A <tt>multiset</tt> is a generalization of the concept of a set that, unlike a set, allows multiple instances of the multiset&#x2019;s elements. Multiset constructors are denoted by two opening curly braces followed by data and two closing curly braces, like &#x201c;{{&#x2026;}}&#x201d;.</p>
754<p>An example would be</p>
755
756<div>
757<div>
758<pre class="source"> {{&quot;hello&quot;, 9328, &quot;world&quot;, [1, 2, null]}}
759</pre></div></div></div></div>
760 </div>
761 </div>
762 </div>
763 <hr/>
764 <footer>
765 <div class="container-fluid">
766 <div class="row-fluid">
767<div class="row-fluid">Apache AsterixDB, AsterixDB, Apache, the Apache
768 feather logo, and the Apache AsterixDB project logo are either
769 registered trademarks or trademarks of The Apache Software
770 Foundation in the United States and other countries.
771 All other marks mentioned may be trademarks or registered
772 trademarks of their respective owners.
773 </div>
774 </div>
775 </div>
776 </footer>
777 </body>
778</html>