XML Mapping
Working with XML data
Hibernate lets you work with persistent XML data in much the same way
you work with persistent POJOs. A parsed XML tree can be thought of
as just another way to represent the relational data at the object level.
Hibernate supports dom4j as API for manipulating XML trees. You can write
queries that retrieve dom4j trees from the database and have any
modification you make to the tree automatically synchronized to the
database. You can even take an XML document, parse it using dom4j, and
write it to the database with any of Hibernate's basic operations:
persist(), saveOrUpdate(), merge(), delete(), replicate()
(merge is not yet supported in Hibernate 3.0rc1).
This feature has many applications including data import/export,
externalization of entity data via JMS or SOAP and XSLT-based reporting.
An single mapping may be used to simultaneously map properties of a class
and nodes of an XML document to the database, or, if there is no class to map,
it may be used to map just the XML.
Note that this is an experimental feature in Hibernate 3.0 and is under
extremely active development.
Specifying XML and class mapping together
Here is an example of mapping a POJO and XML simultaneously:
...
]]>
Specifying just an XML mapping
Here is an example where there is no POJO class:
...
]]>
This mapping will let us access the data as a dom4j tree, or as a graph of
property name/value pairs (java Maps). The property names
are purely logical constructs that may be referred to in HQL queries.
XML mapping metadata
Many Hibernate mapping elements accept the node attribute.
This let's us specify the name of an XML attribute or element that holds the
property or entity data. The format of the node attribute
must be one of the following:
"element-name" - map to the named XML element
"@attribute-name" - map to the named XML attribute
"." - map to the parent element
"element-name/@attribute-name" -
map to the named attribute of the named element
For collections and single valued associations, there is an additional
embed-xml attribute. If embed-xml="true",
the default, the XML tree for the associated entity (or collection of value type)
will be embedded directly in the XML tree for the entity that owns the association.
Otherwise, if embed-xml="false", then only the referenced
identifier value will appear in the XML for single point associations and
collections will simply not appear at all.
You should be careful not to leave embed-xml="true" for
too many associations, since XMl does not deal well with circularity!
...
]]>
in this case, we have decided to embed the collection of account ids, but not
the actual account data. The following HQL query:
Would return datasets such as this:
Gavin
A
King
...
]]>
If we set embed-xml="true" on the <one-to-many>
mapping, the data might look more like this:
100.29
-2370.34
Gavin
A
King
...
]]>
Manipulating XML data
Now that we have mapped our entities to XML, we want to be able to read and
update XML documents in our application. We do this by obtaining a dom4j session:
It is extremely useful to combine this feature with Hibernate's replicate()
operation to implement XML-based data import/export.