XML Editor
Sign up for a WebBoard account Sign Up Keyword Search Search More Options... Options
Chat Rooms Chat Help Help News News Log in to WebBoard Log in Not Logged in
Conferences Close Tree View
+ Stylus Studio Feature Requests (1192)
+ Stylus Studio Technical Forum (14621)
+ Website Feedback (249)
- XSLT Help and Discussion (7625)
-> + Use of before and after string (3) Sticky Topic
-> - How do I substitute element ty... (1)
-> + How does one add working days ... (4)
-> - Help, I have existing XLT and... (1)
-> + Need help on XSLT issue - (2)
-> + EDI to XML Conversion (7)
-> - XML To JSON Conversion using X... (1)
-> + Formatting Paragraphs to same ... (2)
-> - Grouping of records (1)
-> + Problems with xsd 1.1 (4)
-> + XML to HL7 mapping (3)
-> + XSLT 3 and Iterate (2)
-> + XSL-FO to PDF preview (3)
-> + java.lang.RuntimeException: Er... (2)
-> + Create Acroforms with Stylus X... (2)
-> + How to change XSLT parameter s... (3)
-> + how to change format of the da... (2)
-> + Search "Next 8 Results " doesn... (2)
-> - Support for Git (1)
-> + newbee (8)
-- [1-20] [21-40] [41-60] Next
+ XQuery Help and Discussion (2017)
+ Stylus Studio FAQs (159)
+ Stylus Studio Code Samples & Utilities (364)
+ Stylus Studio Announcements (113)
Topic  
Postnext
stelios kousSubject: Combining XML elements based on sub-element value
Author: stelios kous
Date: 06 Jan 2009 06:18 AM
Hi,

I am trying to modify an XML which has resulted from a turning a DB query to XML. eg.

<?xml version="1.0" encoding="utf-8" ?>
<NewDataSet>
- <Table>
<CommonName>Chimpanzee</CommonName>
<NumberOfAnimals>15</NumberOfAnimals>
<PostCode>BN13LW</PostCode>
<Zoo_ID>4</Zoo_ID>
<ZooName>Brighton Zoo</ZooName>
</Table>
- <Table>
<CommonName>African Lion</CommonName>
<NumberOfAnimals>1</NumberOfAnimals>
<PostCode>BN13LW</PostCode>
<Zoo_ID>4</Zoo_ID>
<ZooName>Brighton Zoo</ZooName>
</Table>
- <Table>
- <Table>
<CommonName>Bengal Tiger</CommonName>
<NumberOfAnimals>3</NumberOfAnimals>
<PostCode>PO49PX</PostCode>
<Zoo_ID>5</Zoo_ID>
<ZooName>Portsmouth Zoo</ZooName>
</Table>
</NewDataSet>

Now I need to combine all the "Table" elements where their subelement Zoo_ID has the same value to produce something like:
<Table>
<tr>
<td>Name</td><td> Chimpanzee</td>
</tr>
<tr>
<td>Name</td><td> African Lion</td>
</tr>
<tr>
<td>Zoo Name</td><td>Brighton Zoo</td>
</tr>
<tr>
<td>Zoo Post Code</td><td>BN13LW</td>
</tr>
</Table>
<Table>
<tr>
<td>Name</td><td>Bengal Tiger</td>
</tr>
<tr>
<td>Zoo Name</td><td>Brighton Zoo</td>
</tr>
<tr>
<td>Zoo Post Code</td><td>BN13LW</td>
</tr>
</Table>

but I am unsuccesful creating a template to do so. Can you give me some pointers?

Postnext
(Deleted User) Subject: Combining XML elements based on sub-element value
Author: (Deleted User)
Date: 06 Jan 2009 09:48 AM
You need to perform a grouping operation: see http://www.jenitennison.com/xslt/grouping/index.html for some tutorials.

Alberto

Posttop
stelios kousSubject: Combining XML elements based on sub-element value
Author: stelios kous
Date: 06 Jan 2009 10:03 AM
Hi Alberto,

Thank you for your reply and the link. The issue that puzzles me is how to get the value of "all" the Zoo_IDs in my XML and then group by each of those. As the values come from a Database and this transformation is done programmaticaly I am unsure how to create multiple groupings each by the ZOO_ID.

Apologies for my ignorance but quite new to XSLT and it is difficult to get my head around it at the moment

Stelios

   
Download A Free Trial of Stylus Studio 6 XML Professional Edition Today! Powered by Stylus Studio, the world's leading XML IDE for XML, XSLT, XQuery, XML Schema, DTD, XPath, WSDL, XHTML, SQL/XML, and XML Mapping!  
go

Log In Options

Site Map | Privacy Policy | Terms of Use | Trademarks
Stylus Scoop XML Newsletter:
W3C Member
Stylus Studio® and DataDirect XQuery ™are from DataDirect Technologies, is a registered trademark of Progress Software Corporation, in the U.S. and other countries. © 2004-2016 All Rights Reserved.