dra*_*fly 2 xml sql t-sql sql-server xml-namespaces
您好,我需要 sql 中以下内容的帮助:
我需要创建一个这种格式的xml文件
<Document xmlns="urn:iso:std:iso:20022:tech:xsd:001.002.001.04">
<FIToFIPmtStsRpt>
<GrpHdr>
<MsgId></MsgId>
</GrpHdr>
<OrgnlGrpInfAndSts>
<OrgnlMsgId />
</OrgnlGrpInfAndSts>
</FIToFIPmtStsRpt>
</document>
Run Code Online (Sandbox Code Playgroud)
目前我有一个保存主要信息的变量,并且我建立了信息之间的关系(假设 grphdr 可以使用不同的信息多次插入到主 xml 中)
declare @xml xml='<Document
xmlns="urn:iso:std:iso:20022:tech:xsd:001.002.001.04">
<FIToFIPmtStsRpt>
</FIToFIPmtStsRpt>
</Document>
'
declare @xmlgrp xml='<GrpHdr>
<MsgId></MsgId>
</GrpHdr>'
--here i do some code to fill msgid
Run Code Online (Sandbox Code Playgroud)
然后当我将 grphdr 添加回主 xml 时
SET @xml.modify
('declare namespace a= "urn:iso:std:iso:20022:tech:xsd:001.002.001.04";
insert sql:variable("@xmlgrp")
into (a:Document/a:FIToFIPmtStsRpt)[1]')
select @xml
Run Code Online (Sandbox Code Playgroud)
我需要找出顶级文件格式,但现在发生的情况如下
<Document xmlns="urn:iso:std:iso:20022:tech:xsd:001.002.001.04">
<FIToFIPmtStsRpt>
<GrpHdr xmlns="">-- i need this xmlns tag out
<MsgId />
</GrpHdr>
</FIToFIPmtStsRpt>
</Document>
Run Code Online (Sandbox Code Playgroud)
不知怎的,我需要 xml 中的空 xmlns 标签。我无法转换为 varchar(max) 来删除,因为我们的数据库已将变量限制为 8000 个字符,而我的 xml 可以增长到超过 8000 个。1 个文件中可以有多个 grphdr 或 OrgnlGrpInfAndSts
table: lim_Live_Inbound
lim_msg_id | lim_request_transaction_id | client_name
------------------------------------------------------
021/00210006/20160225/000002 | 00012016-02-25000000023 | Mr Piet
021/00210006/20160225/000002 | 00012016-02-25000000022 | Mrs Name
Run Code Online (Sandbox Code Playgroud)
必须像这样生成
<Document xmlns="urn:iso:std:iso:20022:tech:xsd:001.002.001.04">
<FIToFIPmtStsRpt>
<GrpHdr>
<MsgId>021/00210006/20160225/000002</MsgId>
</GrpHdr>
<OrgnlGrpInfAndSts>
<OrgnlMsgId>00012016-02-25000000023</OrgnlMsgId>
<name>Mr Piet</name>
</OrgnlGrpInfAndSts>
<OrgnlGrpInfAndSts>
<OrgnlMsgId>00012016-02-25000000022</OrgnlMsgId>
<name>Mrs Name</name>
</OrgnlGrpInfAndSts>
</FIToFIPmtStsRpt>
</document>
Run Code Online (Sandbox Code Playgroud)
这就是为什么我尝试插入到 xml 方式。如果有人可以帮助我找到更好的方法,我将不胜感激。
实际上,这个解决方法仍然没有真正的帮助。命名空间xmlns=""被视为*内部的所有内容都不在命名空间内...您可以将结果转换为NVARCHAR(MAX)并使用REPLACE来摆脱xmlns="". 然后您可以将字符串重新转换为XML. 微软感到羞耻,这个 10(!!) 年前的问题(见下面的链接)仍然没有解决。请去那里投票!
DECLARE @lim_Live_Inbound TABLE(lim_msg_id VARCHAR(100),lim_request_transaction_id VARCHAR(100),client_name VARCHAR(100));
INSERT INTO @lim_Live_Inbound VALUES
('021/00210006/20160225/000002','00012016-02-25000000023','Mr Piet')
,('021/00210006/20160225/000002','00012016-02-25000000022','Mrs Name');
DECLARE @nestedXMLs TABLE(MsgId VARCHAR(100),nestedXML XML);
WITH GrpMsg AS
(
SELECT DISTINCT lim_msg_id AS MsgId
FROM @lim_Live_Inbound
)
INSERT INTO @nestedXMLs
SELECT MsgId
,(
SELECT innerTbl.lim_request_transaction_id AS OrgnlMsgId
,innerTbl.client_name AS name
FROM @lim_Live_Inbound AS innerTbl
WHERE innerTbl.lim_msg_id=GrpMsg.MsgId
FOR XML PATH('OrgnlGrpInfAndSts'),TYPE
)
FROM GrpMsg;
WITH XMLNAMESPACES(DEFAULT 'urn:iso:std:iso:20022:tech:xsd:001.002.001.04')
,GrpMsg AS
(
SELECT DISTINCT lim_msg_id AS MsgId
FROM @lim_Live_Inbound
)
SELECT GrpMsg.MsgId AS [GrpHdr/MsgId]
,n.nestedXML AS [node()]
FROM GrpMsg
INNER JOIN @nestedXMLs AS n ON GrpMsg.MsgId=n.MsgId
FOR XML PATH('FIToFIPmtStsRp'),ROOT('Document')
Run Code Online (Sandbox Code Playgroud)
结果
<Document xmlns="urn:iso:std:iso:20022:tech:xsd:001.002.001.04">
<FIToFIPmtStsRp>
<GrpHdr>
<MsgId>021/00210006/20160225/000002</MsgId>
</GrpHdr>
<OrgnlGrpInfAndSts xmlns="">
<OrgnlMsgId>00012016-02-25000000023</OrgnlMsgId>
<name>Mr Piet</name>
</OrgnlGrpInfAndSts>
<OrgnlGrpInfAndSts xmlns="">
<OrgnlMsgId>00012016-02-25000000022</OrgnlMsgId>
<name>Mrs Name</name>
</OrgnlGrpInfAndSts>
</FIToFIPmtStsRp>
</Document>
Run Code Online (Sandbox Code Playgroud)
您可以用来CAST(REPLACE(CAST(TheXMLHere AS NVARCHAR(MAX)),' xmlns=""','') AS XML)摆脱错误的空名称空间......
这是重复命名空间 - 但这在语法上是正确的,但很烦人(请阅读此处: https: //connect.microsoft.com/SQLServer/feedback/details/265956/suppress-namespace-attributes-in-nested-select-for- xml 语句)
DECLARE @lim_Live_Inbound TABLE(lim_msg_id VARCHAR(100),lim_request_transaction_id VARCHAR(100),client_name VARCHAR(100));
INSERT INTO @lim_Live_Inbound VALUES
('021/00210006/20160225/000002','00012016-02-25000000023','Mr Piet')
,('021/00210006/20160225/000002','00012016-02-25000000022','Mrs Name');
WITH XMLNAMESPACES(DEFAULT 'urn:iso:std:iso:20022:tech:xsd:001.002.001.04')
,GrpMsg AS
(
SELECT DISTINCT lim_msg_id AS MsgId
FROM @lim_Live_Inbound
)
SELECT MsgId AS [GrpHdr/MsgId]
,(
SELECT innerTbl.lim_request_transaction_id AS OrgnlMsgId
,innerTbl.client_name AS name
FROM @lim_Live_Inbound AS innerTbl
WHERE innerTbl.lim_msg_id=GrpMsg.MsgId
FOR XML PATH('OrgnlGrpInfAndSts'),TYPE
)
FROM GrpMsg
FOR XML PATH('FIToFIPmtStsRp'),ROOT('Document')
Run Code Online (Sandbox Code Playgroud)
结果
<Document xmlns="urn:iso:std:iso:20022:tech:xsd:001.002.001.04">
<FIToFIPmtStsRp>
<GrpHdr>
<MsgId>021/00210006/20160225/000002</MsgId>
</GrpHdr>
<OrgnlGrpInfAndSts xmlns="urn:iso:std:iso:20022:tech:xsd:001.002.001.04">
<OrgnlMsgId>00012016-02-25000000023</OrgnlMsgId>
<name>Mr Piet</name>
</OrgnlGrpInfAndSts>
<OrgnlGrpInfAndSts xmlns="urn:iso:std:iso:20022:tech:xsd:001.002.001.04">
<OrgnlMsgId>00012016-02-25000000022</OrgnlMsgId>
<name>Mrs Name</name>
</OrgnlGrpInfAndSts>
</FIToFIPmtStsRp>
</Document>
Run Code Online (Sandbox Code Playgroud)
我不知道你的数据来自哪里,但是 - 绝对硬编码 - 这是方法:
WITH XMLNAMESPACES(DEFAULT 'urn:iso:std:iso:20022:tech:xsd:001.002.001.04')
SELECT 0 AS [GrpHdr/MsgId]
,0 AS [OrgnlGrpInfAndSts/OrgnlMsgId]
FOR XML PATH('FIToFIPmtStsRp'),ROOT('Document')
Run Code Online (Sandbox Code Playgroud)
结果
<Document xmlns="urn:iso:std:iso:20022:tech:xsd:001.002.001.04">
<FIToFIPmtStsRp>
<GrpHdr>
<MsgId>0</MsgId>
</GrpHdr>
<OrgnlGrpInfAndSts>
<OrgnlMsgId>0</OrgnlMsgId>
</OrgnlGrpInfAndSts>
</FIToFIPmtStsRp>
</Document>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1941 次 |
| 最近记录: |