blob: 804611a53f10aa4ed84a58c44f8b018017e84517 [file] [log] [blame]
Ian Maxon857dc132015-09-25 17:13:19 -07001/*
2 * Licensed to the Apache Software Foundation (ASF) under one
3 * or more contributor license agreements. See the NOTICE file
4 * distributed with this work for additional information
5 * regarding copyright ownership. The ASF licenses this file
6 * to you under the Apache License, Version 2.0 (the
7 * "License"); you may not use this file except in compliance
8 * with the License. You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing,
13 * software distributed under the License is distributed on an
14 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15 * KIND, either express or implied. See the License for the
16 * specific language governing permissions and limitations
17 * under the License.
18 */
vinayakb38b7ca42012-03-05 05:44:15 +000019use dataverse demo1112;
20
21declare type CustomerType as open {
22 cid: int32,
23 name: string,
24 age: int32?,
25 address: AddressType?,
26 lastorder: {
27 oid: int32,
28 total: float
29 }
30}
31
32declare type AddressType as open {
33 number: int32,
34 street: string,
35 city: string
36}
37
38
39declare type OrderType as open {
40 oid: int32,
41 cid: int32,
42 orderstatus: string,
43 orderpriority: string,
44 clerk: string,
45 total: float
46}
47
Ian Maxonf7b64532015-12-09 17:28:18 -080048declare nodegroup group1 on asterix_nc1, asterix_nc2;
vinayakb38b7ca42012-03-05 05:44:15 +000049
50declare dataset Customers(CustomerType)
ramangrover29669d8f62013-02-11 06:03:32 +000051 primary key cid on group1;
vinayakb38b7ca42012-03-05 05:44:15 +000052declare dataset Orders(OrderType)
ramangrover29669d8f62013-02-11 06:03:32 +000053 primary key oid on group1;
vinayakb38b7ca42012-03-05 05:44:15 +000054
Ian Maxonf7b64532015-12-09 17:28:18 -080055write output to asterix_nc1:"/tmp/split01.adm";
vinayakb38b7ca42012-03-05 05:44:15 +000056
57let $os := for $o in dataset('Orders') return $o
58for $o1 in $os
59for $o2 in $os
60where $o1.cid = $o2.cid
61return { "o1": $o1.oid, "o2": $o2.oid, "cid": $o1.cid }