Sample code for 30+ languages & platforms
SQL Server

Traverse the XML Tree

See more XML Examples

Demonstrates how to traverse all nodes in an XML tree.

Note: This example requires Chilkat v9.5.0.77 or greater.

Chilkat SQL Server Downloads

SQL Server
-- 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

    -- Use the NextInTraversal2 method to traverse all nodes in the XML tree rooted at the caller.

    DECLARE @xml int
    EXEC @hr = sp_OACreate 'Chilkat.Xml', @xml OUT
    IF @hr <> 0
    BEGIN
        PRINT 'Failed to create ActiveX component'
        RETURN
    END

    EXEC sp_OAMethod @xml, 'LoadXmlFile', @success OUT, 'qa_data/xml/twoPigs.xml'

    -- This is the XML traversed in this example:

    -- <pig-rescue>
    --   <herd name="Cathy">
    -- 	<species name="pot belly pig">
    -- 	    <animal>
    -- 	        <name>Molly II</name>
    -- 	        <birth>February, 1998</birth>
    -- 			<in-date>January, 2000</in-date>
    -- 			<from>Middle Ave.</from>
    -- 			<gender spay-neuter="yes">F</gender>
    -- 			<info>Molly came from a place where an old, ill man had too many animals.
    -- 	              	The animals were seldom fed and rats would eat the newborn piglets.
    -- 	             	 When Molly was found at one week old, she was the only piglet of 
    -- 	              	her siblings who did not get stepped on by a cow. She is a sweet, 
    -- 	              	friendly pig who likes to hang out on Cathy's porch on the lounge 
    -- 	              	pad.
    -- 			</info>
    -- 		</animal>
    -- 	    <animal>
    -- 			<name>Nigel</name>
    -- 			<birth>June, 1991</birth>
    -- 			<in-date>August, 1991</in-date>
    -- 			<from>Breeder</from>
    -- 			<gender spay-neuter="no">M</gender>
    -- 			<info>
    -- 			 	Nigel was the first pig and the reason for the rescue in the
    -- 			 	first place. He is 13 now and doing well, but takes a number 
    -- 				of medications, as you can see below.
    -- 			</info>
    -- 		</animal>		
    -- 	</species>
    --   </herd>
    -- </pig-rescue>

    -- The sbState is an object used to keep track of the current state of the traversal.
    DECLARE @sbState int
    EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbState OUT

    EXEC sp_OAMethod @xml, 'NextInTraversal2', @iTmp0 OUT, @sbState
    WHILE @iTmp0 <> 0
      BEGIN

        EXEC sp_OAGetProperty @xml, 'Tag', @sTmp0 OUT
        PRINT @sTmp0
        EXEC sp_OAGetProperty @xml, 'TagPath', @sTmp0 OUT
        PRINT @sTmp0

        PRINT ''

      END

    -- Produces the following output:

    -- herd
    -- herd
    -- 
    -- species
    -- herd|species
    -- 
    -- animal
    -- herd|species|animal[0]
    -- 
    -- name
    -- herd|species|animal[0]|name
    -- 
    -- birth
    -- herd|species|animal[0]|birth
    -- 
    -- in-date
    -- herd|species|animal[0]|in-date
    -- 
    -- from
    -- herd|species|animal[0]|from
    -- 
    -- gender
    -- herd|species|animal[0]|gender
    -- 
    -- info
    -- herd|species|animal[0]|info
    -- 
    -- animal
    -- herd|species|animal[1]
    -- 
    -- name
    -- herd|species|animal[1]|name
    -- 
    -- birth
    -- herd|species|animal[1]|birth
    -- 
    -- in-date
    -- herd|species|animal[1]|in-date
    -- 
    -- from
    -- herd|species|animal[1]|from
    -- 
    -- gender
    -- herd|species|animal[1]|gender
    -- 
    -- info
    -- herd|species|animal[1]|info
    -- 

    EXEC @hr = sp_OADestroy @xml
    EXEC @hr = sp_OADestroy @sbState


END
GO