[xquery-talk] Changing the content of an XML document
john.snelson at oracle.com
Tue Sep 2 12:02:18 PDT 2008
The identity transform will work, and is essentially the same as the
transformation function that Wolfgang suggests. However I think a
transform expression is easier to understand if eXist supports XQuery
copy $a := $tree
modify replace value of node $a//subnode with
if($condition) then "some text" else "some other text"
Christian Schlaefcke wrote:
> Hi Georg,
> take a look at this thread:
> I had a similar problem exept I wanted to delete certain nodes instead of
> replacing them.
> Espacially the "identity transform"
> (http://en.wikipedia.org/wiki/Identity_transform) hint was very helpful
> and it sounds as it could help you with your problem too.
> Best regards,
>>> Wolfgang [mailto:wolfgang at exist-db.org] wrote:
>>>> This means, in the script I load the XML file into a
>>>> local variable using the doc() function and return the result to the
>>> > But now, occationally some of the content of the file has
>>> to be altered.
>>> I'm not sure I completely understand the question. Is the document
>>> stored in the db or do you load it from the filesystem? And
>>> do you only
>>> need to temporarily change some content of that file (in which case I
>>> would probably call an XSLT) or permanently (use XQuery
>>> update extensions)?
>> Actually I can reduce my question to the following: Assuming I have a
>> variable which stores a node-tree like that
>> let $tree :=
>> some text
>> In reality $tree is the entire XML file which I want to send back to the
>> client. Now, depending on some conditions I want to change the content
>> of <subnode> "some text" to "some other text", before sending it. I
>> don't actually want to alter the file in the database, just the message
>> that I'm sending.
>> If I placed the XML-file inside the script, I would write something like
>> if ($condition)
>> then "some text"
>> else "some other text"
>> But since I have a couple of not too small XML files I fear that this
>> will get a bit overcrwoded.
>> Do you understand what I mean?
> talk at x-query.com
John Snelson, Oracle Corporation http://snelson.org.uk/john
Berkeley DB XML: http://oracle.com/database/berkeley-db/xml
More information about the talk