Grouping by department : group « XQuery « XML

XML
1. CSS Style
2. SVG
3. XML Schema
4. XQuery
5. XSLT stylesheet
Java
XML Tutorial
Java Tutorial
Java Source Code / Java Documentation
Java Open Source
Jar File Download
Java Articles
Java Products
Java by API
C# / C Sharp
C# / CSharp Tutorial
ASP.Net
ASP.NET Tutorial
JavaScript DHTML
JavaScript Tutorial
JavaScript Reference
HTML / CSS
HTML CSS Reference
C / ANSI-C
C Tutorial
C++
C++ Tutorial
Ruby
PHP
Python
SQL Server / T-SQL
SQL Server / T-SQL Tutorial
Oracle PL / SQL
Oracle PL/SQL Tutorial
PostgreSQL
SQL / MySQL
MySQL Tutorial
VB.Net
VB.Net Tutorial
Flash / Flex / ActionScript
VBA / Excel / Access / Word
Microsoft Office PowerPoint 2007 Tutorial
Microsoft Office Excel 2007 Tutorial
Microsoft Office Word 2007 Tutorial
XML » XQuery » group 
Grouping by department



File: Data.xml

<inventory id="inv0001" date="2008-12-19" loc="USA">
  <car model="A" id="0001" quantity="1" color="navy"/>
  <car model="B" id="0002" quantity="1"/>
  <car model="B" id="0003" quantity="2"/>
  <car model="C" id="0004" quantity="1" color="white"/>
  <car model="A" id="0001" quantity="1" color="black"/>
</inventory>




File: Query.xquery

for $d in distinct-values(doc("Data.xml")//car/@model)
let $cars := doc("Data.xml")//car[@model = $d]
order by $d
return <department code="{$d}">{
         for $i in $cars
         order by $i/@id
         return $i
       }</department>


Output:

<?xml version="1.0" encoding="UTF-8"?>
<department code="A">
   <car model="A" id="0001" quantity="1" color="navy"/>
   <car model="A" id="0001" quantity="1" color="black"/>
</department>
<department code="B">
   <car model="B" id="0002" quantity="1"/>
   <car model="B" id="0003" quantity="2"/>
</department>
<department code="C">
   <car model="C" id="0004" quantity="1" color="white"/>
</department>

 
Related examples in the same category
1. Grouping in XQuery
www.java2java.com | Contact Us
Copyright 2010 - 2030 Java Source and Support. All rights reserved.
All other trademarks are property of their respective owners.