blob: 7529844ef40354666f7e7725d0e548cb8c4220b8 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
drop dataverse events if exists;
create dataverse events;
use dataverse events;
create type AddressType as closed {
street: string,
city: string,
zip: string
//, latlong: point
}
create type EventType as closed {
name: string,
location: AddressType ?,
organizers: {{
{
name: string,
role: string
}
}},
sponsoring_sigs: [
{
sig_name: string,
chapter_name: string
}
],
interest_keywords: {{string}},
price: double?,
start_time: datetime,
end_time: datetime
}
create nodegroup group1 if not exists on nc1, nc2;
create dataset Event(EventType) primary key name on group1;
write output to nc1:"/tmp/q2.adm";
for $event in dataset('Event')
for $sponsor in $event.sponsoring_sigs
let $es := { "event": $event, "sponsor": $sponsor }
group by $sig_name := $sponsor.sig_name with $es
let $sig_sponsorship_count := count($es)
let $by_chapter :=
for $e in $es
group by $chapter_name := $e.sponsor.chapter_name with $e
return { "chapter_name": $chapter_name, "escount" : count($e) }
order by $sig_sponsorship_count desc
limit 5
return { "sig_name": $sig_name, "total_count": $sig_sponsorship_count, "chapter_breakdown": $by_chapter }