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)
-> + Merging Table Cells in XSLT re... (3)
-> + xsl fo block-container and foo... (2)
-> + Is is possible to create a .CO... (2)
-> + printing a parent node value i... (2)
-> + Mime header info setup? (3)
-> + Calculating a Date based on 4 ... (3)
-> + XSLT formatting number issue (10)
-> + map repeating elements separat... (3)
-> - Combining XML elements based o... (3)
-> ->Combining XML elements ba...
-> ->Combining XML elements ba...
-> + Convert XML to UTF-8 (8)
-> + XSLT and MS Access 2007 Optio... (5)
-> - WORDML list to XML list (1)
-> + [Newbie] Using lookups in XSLT... (3)
-> + Comparing 2 passed Date Values (2)
-> + ERROR XQueryMediator Error du... (2)
-> + XML / XSLT... Unordered lists ... (2)
-> + Specify image path in XSL (2)
-> + Variable within a variable (3)
-> + How to call jfreechart method ... (8)
-> + leading and trailing white spa... (2)
-- Previous [421-440] [441-460] [461-480] 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.