首页 >数据库 >mysql教程 >如何消除嵌套 FOR XML PATH 查询中的冗余命名空间?

如何消除嵌套 FOR XML PATH 查询中的冗余命名空间?

Susan Sarandon
Susan Sarandon原创
2025-01-05 17:57:40302浏览

How to Eliminate Redundant Namespaces in Nested FOR XML PATH Queries?

使用嵌套查询处理 FOR XML PATH 中的冗余命名空间

在使用 WITH XMLNAMESPACES 声明默认命名空间的 FOR XML PATH 查询中,冗余命名空间声明可能出现在嵌套查询的顶级节点中。为了解决这个问题,一种有效的解决方案是利用 FOR XML EXPLICIT,如下所示:

DECLARE @Order TABLE (OrderID INT, OrderDate DATETIME)
DECLARE @OrderDetail TABLE (OrderID INT, ItemID VARCHAR( 1), 名称 VARCHAR(50), 数量 INT)

--初始化表
INSERT @Order VALUES (1, '2010-01-01'), (2, '2010-01-02')
INSERT @OrderDetail VALUES
(1, 'A', '喝', 5),
(1, 'B', '杯子', 2),
(2, 'A', '饮料', 2),
(2, 'C', '吸管', 1),
(2, 'D', '餐巾' , 1)

-- 执行嵌套的 FOR XML PATH 查询
DECLARE @xml XML = (
SELECT

OrderID AS "@OrderID",
(
  SELECT
    ItemID AS "@ItemID",
    Name AS "data()"
  FROM @OrderDetail
  WHERE OrderID = o.OrderID
  FOR XML PATH('Item'), TYPE
)

FROM @Order o
FOR XML PATH('Order'), ROOT('dummyTag'), TYPE
)

-- 删除多余的命名空间并根节点使用 FOR XML EXPLICIT
SELECT
1 AS 标签,
NULL AS父级,
@xml AS [xml!1!!xmltext],
'http://test.com/order' AS [xml!1!xmlns]
FOR XML EXPLICIT

这种查询组合有效地从嵌套查询中删除了冗余的命名空间,同时在顶层保留了必要的声明。结果是一个格式良好的 XML 文档,具有单个、正确命名的根元素。

以上是如何消除嵌套 FOR XML PATH 查询中的冗余命名空间?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn