Using XQuery Update
Saxon-EE supports use of the update extensions to XQuery defined in the W3C Recommendation http://www.w3.org/TR/xquery-update-10/.
Update is available only in Saxon-EE, and is supported only if explicitly requested. The
command line has an option
-update:on for this purpose, and all the XQuery
APIs have an option to enable updating, which must be set before compiling the query. If
this option is not set, the parser will not recognize update syntax, and any use of
updating expressions will trigger a syntax error.
It is possible for an update to modify the document supplied as the context item, or a
document read using the
collection() function, or even a
document constructed dynamically by the query itself. When using the various APIs, the
general policy is that updated documents are never written automatically to disk. Instead,
the list of updated documents is available to the application on completion of the query,
and the application can decide whether to save the documents to their original location, or
to some other location. Documents that were originally read from disk will have a document
URI property which can be used to decide where to write them back.
When using XQuery Update from the command line, updated documents will be written back to
disk if they have a known document URI, and if that URI is an updatable location (which in
practice means it must be a URI that uses the
file:// scheme). For testing
purposes, the write-back can be suppressed by using
-update:discard. There is
-backup option to control whether the old file is saved under a
different name before being overwritten.
Most errors that can arise during updating operations (for example, inserting two conflicting attributes) will cause an exception, with the supplied input document in memory being left in its original state. However, errors detected during the validation phase (that is, when the updated document is invalid against the schema, assuming revalidation is requested) are non-recoverable; after such a failure, the state of the document is unpredictable. Generally the (invalid) updates will have been made, and some of the updates done during schema validation (setting type annotations and default values) may also have been made.
Note that updates to a document will fail unless it is implemented using the Linked
Tree model. This can be selected from the command line using
-tree:linked, or via configuration settings in the API. It is not at
present possible to update the Tiny Tree, nor external object models such as DOM, JDOM2, or