How can I nest stored procedures that return XML using FOR XML PATH?

728 views Asked by At

I have a FOR XML PATH Stored Procedure that returns some XML in the usual manner (shortened for clarity):

CREATE PROCEDURE sp_returnsubnode
AS
BEGIN
SELECT  subnode.subnodeid "@subnodeid"
       ,subnode.somedata "somedata"
FROM subnode
FOR XML PATH('subnode')
END

I have another stored procedure that I would like to include the results of the above query within e.g.

CREATE PROCEDURE sp_returnmainxml
AS
BEGIN
SELECT  node.nodeid "@nodeid"
       ,node.nodedata "data"
       ,[AT THIS POINT I WOULD LIKE TO CALL sp_returnsubnode AND NEST IT]
       ,node.moredata "moredata"
FROM node
FOR XML PATH ('node')
END

But the methods I have tried like assigning the results of executing sp_subnode to an xml datatype and attempting to nest that have failed.

This seems like something people would want to do often but I haven't found any reference on how to do it. Is it even possible?

1

There are 1 answers

1
Mikael Eriksson On BEST ANSWER

You can do this with a user defined functions that returns XML.

A function returning XML:

create function getsubnode(@P int)
returns xml as
begin
  return (
          select @P as '@subnodeid',
                 'SubNodData' as somedata
          for xml path('subnode'), type
         ) 
end

Use like this:

select nodeid as '@nodeid',
       nodedata as data,
       dbo.getsubnode(nodeid),
       moredata
from node
for xml path('node')