在SQL Server中使用FOR XML PATH查询分层数据的XML输出
发布时间:2020-05-23 10:47:00 所属栏目:MsSql 来源:互联网
导读:我有一个表有NodeId,NodeName,ParentNodeId的列,我想以Xml的形式输出整个表数据,如下所示使用SQL查询.我认为FOR SQL PATH模式在Sql server中可以用来实现这个(我使用SQL Server 2008)使用递归,但不知道如何.提前致谢 ?xml version=1.0 encoding=utf-8 ?Nodes
|
我有一个表有NodeId,NodeName,ParentNodeId的列,我想以Xml的形式输出整个表数据,如下所示使用SQL查询.我认为FOR SQL PATH模式在Sql server中可以用来实现这个(我使用SQL Server 2008)使用递归,但不知道如何.提前致谢 <?xml version="1.0" encoding="utf-8" ?>
<Nodes>
<Node Id="1" Name="node1">
<Node Id="11" Name="node11">
<Node Id="111" Name="node111" />
<Node Id="112" Name="node112" />
</Node>
</Node>
<Node Id="2" Name="node2">
<Node Id="21" Name="node21">
<Node Id="211" Name="node211" />
<Node Id="212" Name="node212" />
</Node>
</Node>
</Nodes>
解决方法我使用存储过程和递归函数来解决它.代码如下. (实际上我想要生成一个菜单xml,所以菜单显示的代码.CREATE PROCEDURE [dbo].[usp_GetMenu]
AS
BEGIN
SET NOCOUNT ON;
SELECT dbo.fnGetMenuItems(MenuId)
FROM dbo.Menu
WHERE ParentMenuId IS NULL
FOR XML PATH('MenuItems')
END
GO
CREATE FUNCTION [dbo].[fnGetMenuItems]
(
@MenuId int
)
RETURNS XML
WITH RETURNS NULL ON NULL INPUT
AS
BEGIN
RETURN
(
SELECT MenuId AS "@Id",[Name] AS "@Name",[URL] AS "@URL",[Key] AS "@Key",[dbo].[fnGetMenuItems](MenuId)
FROM dbo.Menu
WHERE ParentMenuId = @MenuId
FOR XML PATH('MenuItem'),TYPE
)
END
GO (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
热点阅读
