SQL Server
SQL Server
Removing / Deleting Child Nodes from XML
See more XML Examples
Demonstrates various methods for removing child nodes from an XML document.The input XML, available at http://www.chilkatsoft.com/data/fruit.xml, is this:
<root>
<fruit color="red">apple</fruit>
<fruit color="green">pear</fruit>
<veg color="orange">carrot</veg>
<meat animal="cow">beef</meat>
<xyz>
<fruit color="blue">blueberry</fruit>
<veg color="green">broccoli</veg>
</xyz>
<fruit color="purple">grape</fruit>
<cheese color="yellow">cheddar</cheese>
</root>
Chilkat SQL Server Downloads
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls.
--
CREATE PROCEDURE ChilkatSample
AS
BEGIN
DECLARE @hr int
DECLARE @iTmp0 int
-- Important: Do not use nvarchar(max). See the warning about using nvarchar(max).
DECLARE @sTmp0 nvarchar(4000)
DECLARE @success int
SELECT @success = 0
DECLARE @xml int
EXEC @hr = sp_OACreate 'Chilkat.Xml', @xml OUT
IF @hr <> 0
BEGIN
PRINT 'Failed to create ActiveX component'
RETURN
END
DECLARE @xyz int
-- The sample input XML is available at http://www.chilkatsoft.com/data/fruit.xml
EXEC sp_OAMethod @xml, 'LoadXmlFile', @success OUT, 'fruit.xml'
IF @success <> 1
BEGIN
EXEC sp_OAGetProperty @xml, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @xml
RETURN
END
-- The RemoveChild method removes (discards) all direct
-- children having the specified tag:
EXEC sp_OAMethod @xml, 'RemoveChild', NULL, 'fruit'
-- Show the resulting XML:
PRINT 'Result with all direct children having a tag equal to "fruit" removed:'
EXEC sp_OAMethod @xml, 'GetXml', @sTmp0 OUT
PRINT @sTmp0
-- The XML with the "fruit" direct children removed is shown below:
-- Notice that the "fruit" node beneath "xyz" was not removed.
-- This correct because it was not a direct child of the calling node.
-- <root>
-- <veg color="orange">carrot</veg>
-- <meat animal="cow">beef</meat>
-- <xyz>
-- <fruit color="blue">blueberry</fruit>
-- <veg color="green">broccoli</veg>
-- </xyz>
-- <cheese color="yellow">cheddar</cheese>
-- </root>
-- --------------------------------------------------------------------------
-- Restore the original XML:
EXEC sp_OAMethod @xml, 'LoadXmlFile', @success OUT, 'fruit.xml'
-- The RemoveChildWithContent method removes the child
-- having the exact content specified, regardless of the tag.
-- For example:
EXEC sp_OAMethod @xml, 'RemoveChildWithContent', NULL, 'pear'
-- Show the resulting XML:
PRINT 'Result with the node containing "pear" removed:'
EXEC sp_OAMethod @xml, 'GetXml', @sTmp0 OUT
PRINT @sTmp0
-- --------------------------------------------------------------------------
-- Restore the original XML:
EXEC sp_OAMethod @xml, 'LoadXmlFile', @success OUT, 'fruit.xml'
-- The RemoveChildByIndex method removes the Nth direct
-- child. Indexing begins at 0. The "xyz" child is at index 4:
EXEC sp_OAMethod @xml, 'RemoveChildByIndex', NULL, 4
-- Show the resulting XML:
-- Notice that the entire "xyz" subtree is removed.
PRINT 'Result with the node at index 4 removed:'
EXEC sp_OAMethod @xml, 'GetXml', @sTmp0 OUT
PRINT @sTmp0
-- --------------------------------------------------------------------------
-- Restore the original XML:
EXEC sp_OAMethod @xml, 'LoadXmlFile', @success OUT, 'fruit.xml'
-- Navigate to the node with tag "xyz"
EXEC sp_OAMethod @xml, 'FindChild', @xyz OUT, 'xyz'
-- Remove the "xyz" subtree making it it's own XML document
-- with the "xyz" node at the root:
EXEC sp_OAMethod @xyz, 'RemoveFromTree', NULL
-- Show both XML documents:
EXEC sp_OAMethod @xyz, 'GetXml', @sTmp0 OUT
PRINT @sTmp0
EXEC sp_OAMethod @xml, 'GetXml', @sTmp0 OUT
PRINT @sTmp0
-- Also, the TreeId property is an integer value assigned
-- to nodes in an XML document. All nodes belonging to
-- the same XML document will have the same TreeId.
-- Notice that the "xyz" node now has a different TreeId:
EXEC sp_OAGetProperty @xyz, 'TreeId', @iTmp0 OUT
PRINT 'xyz TreeId = ' + @iTmp0
EXEC sp_OAGetProperty @xml, 'TreeId', @iTmp0 OUT
PRINT 'xml TreeId = ' + @iTmp0
EXEC @hr = sp_OADestroy @xyz
EXEC @hr = sp_OADestroy @xml
END
GO