如何使用Mule 4中的Dataweave将以下SQL输出转换为XML?
SELECT s.RefId
,s.LocalId
,s.StateProvinceId
,s.SchoolName
,e.Email
,e.EmailType
FROM SchoolInfo s
LEFT OUTER JOIN SchoolEmail e
ON e.SchoolRefId = s.RefId
WHERE s.RefId = :ref_id
SQL的输出是:
RefId LocalId StateProvinceId SchoolName Email Type
7FDF722B-6BBA-4BF0-8205-A5380B269EF1 1 SA Steve's School [email protected] prm
7FDF722B-6BBA-4BF0-8205-A5380B269EF1 1 SA Steve's School [email protected] sec
XML输出应如下所示:
<ns0:SchoolInfo xmlns:ns0="http://www.sifassociation.org/datamodel/au/3.4" RefId="7FDF722B-6BBA-4BF0-8205-A5380B269EF1">
<ns0:LocalId>1</ns0:LocalId>
<ns0:StateProvinceId>SA</ns0:StateProvinceId>
<ns0:SchoolName>Steve's School</ns0:SchoolName>
<ns0:SchoolEmailList>
<ns0:Email Type="prm">[email protected]</ns0:Email>
<ns0:Email Type="sec">[email protected]</ns0:Email>
</ns0:SchoolEmailList>
</ns0:SchoolInfo>
谢谢,史蒂夫
只是对我上面的评论进行跟进。整个解决方案通过T-SQL。
SQL
-- DDL and sample data population, start
DECLARE @SchoolInfo TABLE
(
RefId VARCHAR(40) PRIMARY KEY,
LocalId INT,
StateProvinceId CHAR(2),
SchoolName VARCHAR(30)
);
DECLARE @SchoolEmail TABLE
(
ID INT PRIMARY KEY,
RefId VARCHAR(40),
Email VARCHAR(30),
EmailType CHAR(3)
);
INSERT @SchoolInfo (RefId, LocalId, StateProvinceId, SchoolName) VALUES
('7FDF722B-6BBA-4BF0-8205-A5380B269EF1', 1, 'CA', 'Steve''s School');
INSERT INTO @SchoolEmail (ID, RefId, Email, EmailType) VALUES
(1, '7FDF722B-6BBA-4BF0-8205-A5380B269EF1', '[email protected]', 'prm')
,(2, '7FDF722B-6BBA-4BF0-8205-A5380B269EF1', '[email protected] ', 'sec');
-- DDL and sample data population, end
DECLARE @ref_id VARCHAR(40) = '7FDF722B-6BBA-4BF0-8205-A5380B269EF1';
;WITH xmlnamespaces ('http://www.sifassociation.org/datamodel/au/3.4' AS ns0)
SELECT s.RefId AS [@RefId]
, s.LocalId AS [ns0:LocalId]
, s.StateProvinceId AS [ns0:StateProvinceId]
, s.SchoolName AS [ns0:SchoolName]
, (
SELECT e.EmailType AS [ns0:Email/@Type]
, e.Email AS [ns0:Email]
FROM @SchoolEmail AS e
WHERE e.RefId = s.RefId
FOR XML PATH(''), TYPE, ROOT('ns0:SchoolEmailList')
)
FROM @SchoolInfo AS s
WHERE s.RefId = @ref_id
FOR XML PATH('ns0:SchoolInfo'), TYPE;
输出
<ns0:SchoolInfo xmlns:ns0="http://www.sifassociation.org/datamodel/au/3.4" RefId="7FDF722B-6BBA-4BF0-8205-A5380B269EF1">
<ns0:LocalId>1</ns0:LocalId>
<ns0:StateProvinceId>CA</ns0:StateProvinceId>
<ns0:SchoolName>Steve's School</ns0:SchoolName>
<ns0:SchoolEmailList xmlns:ns0="http://www.sifassociation.org/datamodel/au/3.4">
<ns0:Email Type="prm">[email protected]</ns0:Email>
<ns0:Email Type="sec">[email protected] </ns0:Email>
</ns0:SchoolEmailList>
</ns0:SchoolInfo>
这里是将生成相同XML的DW表达式:
%dw 2.0
output application/xml
ns ns0 http://www.sifassociation.org/datamodel/au/3.4
var rId = payload[0].RefId
var lId = payload[0].LocalId
var sId = payload[0].StateProvinceId
---
ns0#SchoolInfo @(RefId: rId): {
ns0#LocalId: lId,
ns0#StateProvinceId: sId,
ns0#SchoolEmailList: payload reduce (e,acc={}) -> acc ++ {
ns0#Email @(Type: e.Type): e.Email
}
}
我假设每个查询的RefId
,LocalId
和StateProvinceId
始终相同。