【发布时间】:2021-07-22 10:12:59
【问题描述】:
我有以下查询:
WITH XMLNAMESPACES ('https://www.my.namespace.com' as ns)
SELECT
Q.DocType AS [@typeP],
Q.RefNo AS [@idP],
Q.Id AS [@kode],
D.DocId AS [@idDoc],
N.NotId AS [@idNot],
CONVERT(char(10), N.CreDate, 126) AS [@date],
'Text' AS [TN/@Z],
@T2 AS [TN/T]
,(select Adr AS [Adr] from ##TEMP FOR XML PATH (''), type)
FROM
[DB].[dbo].[Q] AS Q
LEFT JOIN [DB].[dbo].[D] AS D ON Q.Id=D.Id
LEFT JOIN [DB].[dbo].[N] AS N ON D.DocId=N.DocuId
WHERE
Q.InboxId= Cast(@InboxId as varchar(15))
FOR XML PATH ('Not');
结果我得到了 XML:
<Not xmlns:ns="https://www.my.namespace.com"
typeP="4532"
idP="90210"
kode="YCV06N1L-FMDA-YPXZ-5H4F-BLA75C6G86KI"
idDoc="49"
idNot="456"
date="2021-07-19">
<TN Text="T">
<T>some text</T>
</TN>
<Adr xmlns:ns="https://www.my.namespace.com">10800234</Adr>
<Adr xmlns:ns="https://www.my.namespace.com">24900005</Adr>
<Adr xmlns:ns="https://www.my.namespace.com">24900004</Adr>
<Adr xmlns:ns="https://www.my.namespace.com">10201026</Adr>
<Adr xmlns:ns="https://www.my.namespace.com">66600019</Adr>
<Adr xmlns:ns="https://www.my.namespace.com">14042243</Adr>
</Not>
如何从 Adr 节点中删除命名空间?我想得到:
<Adr>10800234</Adr>
...
<Adr>14042243</Adr>
请告知我在这里做错了什么。
如果有任何解决方案,我将不胜感激。
【问题讨论】:
-
你需要去掉'Adr'的'FOR XML PATH'。
-
然后我会得到:无效的对象名称'TYPE'。如果我也删除“类型”,则:子查询返回超过 1 个值。当子查询跟随 =、!=、、>= 或子查询用作表达式时,这是不允许的。
-
我可以看到
xmlns:ns正在被定义 - 但它引用了什么?为什么需要它? -
该命名空间(当然这里只是为了简化而改变)根据需要包含在文档规范中。所以必须只包含在根节点。
标签: sql-server xml tsql