Working with XML Data Sources

To access XML data while building a report, you can use facilities of DataSet to read XML into it and then pass it to the assembler as a data source. However, if your scenario does not permit to specify XML schema while loading XML into DataSet, all attributes and text values of XML elements are loaded as strings then. Thus, it becomes impossible, for example, to use arithmetic operations on numbers or to specify custom date-time and numeric formats to output orresponding values, because all of them are treated as strings. To overcome this limitation, you can pass an XmlDataSource instance to the assembler as a data source instead. Even when XML schema is not provided, XmlDataSource is capable to recognize values of the following types by their string representations:

  • Int32?
  • Int64?
  • Double?
  • Boolean?
  • DateTime?

Treating the top-level XML element contains only a sequence of elements of the same type

In template documents, if a top-level XML element contains only a sequence of elements of the same type, an XmlDataSource instance should be treated in the same way as if it was a *DataTable *instance (see “Working with DataTable and DataView Objects” for more information).

Suppose we have XML data like:

John Doe 30 1989-04-01 4:00:00 pm Jane Doe 27 1992-01-31 07:00:00 am John Smith 51 1968-03-08 1:00:00 pm

By using the template like following:

«foreach [in persons]»Name: «[Name]», Age: «[Age]», Date of Birth: «[Birth]:“dd.MM.yyyy"» «/foreach» Average age: «[persons.average(p => p.Age)]»

The results will be produced like:

Name: John Doe, Age: 30, Date of Birth: 01.04.1989 Name: Jane Doe, Age: 27, Date of Birth: 31.01.1992 Name: John Smith, Age: 51, Date of Birth: 08.03.1968 Average age: 36

Treating the top-level XML element contains attributes or nested elements of different types

If a top-level XML element contains attributes or nested elements of different types, an XmlDataSource instance should be treated in template documents in the same way as if it was a DataRow instance (see “Working with DataRow and DataRowView Objects” for more information) as shown in the following example.

Suppose we have XML data like:

John Doe 30 1989-04-01 4:00:00 pm Ann Doe Charles Doe

By using the template like following:

Name: «[Name]», Age: «[Age]», Date of Birth: «[Birth]:“dd.MM.yyyy"» Children: «foreach [in Child]»«[Child_Text]» «/foreach»

The results will be produced like:

Name: John Doe, Age: 30, Date of Birth: 01.04.1989 Children: Ann Doe Charles Doe

The complete example

The following example sums up typical scenarios involving nested complex-type XML elements.

XML

John Smith A Company 1200000 B Ltd. 750000 C & D 350000 Tony Anderson E Corp. 650000 F & Partners 550000 July James G & Co. 350000 H Group 250000 I & Sons 43 100000 J Ent. 100000

Template document

«foreach [in managers]»Manager: «[Name]» Contracts: «foreach [in Contract]»- «[Client.Name]» ($«[Price]») «/foreach» «/foreach»

Source code

Result document

Manager: John Smith Contracts:

  • A Company ($1200000)
  • B Ltd. ($750000)
  • C & D ($350000) Manager: Tony Anderson Contracts:
  • E Corp. ($650000)
  • F & Partners ($550000) Manager: July James Contracts:
  • G & Co. ($350000)
  • H Group ($250000)
  • I & Sons ($100000)
  • J Ent. ($100000)

Download

Data Source Document

Template