2つのXMLファイルを開発する次のコードがありますが、それらを複数の組織タグを持つ1つのファイル自体に含めたいです。
SELECT
LTRIM(RTRIM(c1.cptname)) as "orgHeader/orgCode",
LTRIM(RTRIM(c1.cptname)) as "orgHeader/longName",
LTRIM(RTRIM(c1.cptname)) as "orgHeader/shortName",
'Branch' as "orgRole",
(
SELECT system, extCode from
(
Select 'a' AS 'system', LTRIM(RTRIM(c1.cptname)) AS
'extCode'
UNION ALL
Select 'b' AS 'system', LTRIM(RTRIM(c1.cptname)) AS
'extCode'
UNION ALL
Select 'Manual' AS 'system', LTRIM(RTRIM(c1.cptname)) AS
'extCode'
) a
FOR XML PATH('externalCode'), TYPE, ELEMENTS,Root('externalCodes')
)
from cpt c1
where cptleagname like '%abc%'
and cptcod IN (select cptcod from pf_map
where pf IN ('abc','abc-jp')
and stat = 'a')
FOR XML PATH('organisation'), root ('collection')
SELECT
LTRIM(RTRIM(c1.cptname))+'.' as "orgHeader/orgCode",
LTRIM(RTRIM(c1.cptname))+'.' as "orgHeader/longName",
LTRIM(RTRIM(c1.cptname))+'.' as "orgHeader/shortName",
(
SELECT orgRole from
(
Select 'Coll' AS 'orgRole'
UNION ALL
Select 'Lega' AS 'orgRole'
) a
FOR XML PATH(''), TYPE, ELEMENTS
)
from cpt c1
where cptleagname like '%abc%'
and cptcod IN (select cptcod from pf_map
where pf IN ('abc','abc-jp')
and stat = 'a')
FOR XML PATH('organisation'), root ('collection')
これを実行すると、次のように2つのXMLファイルが出力として生成されます。
<collection>
<organisation>
<orgHeader>
<orgCode>abc</orgCode>
<longName>abc</longName>
<shortName>abc</shortName>
</orgHeader>
<orgRole>Branch</orgRole>
<externalCodes>
<externalCode>
<system>a</system>
<extCode>abc</extCode>
</externalCode>
<externalCode>
<system>b</system>
<extCode>abc</extCode>
</externalCode>
<externalCode>
<system>Manual</system>
<extCode>abc</extCode>
</externalCode>
</externalCodes>
</organisation>
そして
<collection>
<organisation>
<orgHeader>
<orgCode>abc.</orgCode>
<longName>abc.</longName>
<shortName>abc.</shortName>
</orgHeader>
<orgRole>Coll</orgRole>
<orgRole>Leg</orgRole>
</organisation>
</collection>
単一のファイルの下に追加して、ルートとしてコレクションとして結果を生成し、次のようにこれらのファイルを組織タグにマージしたいと思います。
<collection>
<organisation>
<orgHeader>
<orgCode>abc</orgCode>
<longName>abc</longName>
<shortName>abc</shortName>
</orgHeader>
<orgRole>Branch</orgRole>
<externalCodes>
<externalCode>
<system>a</system>
<extCode>abc</extCode>
</externalCode>
<externalCode>
<system>b</system>
<extCode>abc</extCode>
</externalCode>
<externalCode>
<system>Manual</system>
<extCode>abc</extCode>
</externalCode>
</externalCodes>
</organisation>
<organisation>
<orgHeader>
<orgCode>abc.</orgCode>
<longName>abc.</longName>
<shortName>abc.</shortName>
</orgHeader>
<orgRole>Coll</orgRole>
<orgRole>Leg</orgRole>
</organisation>
</collection>
その他の情報が必要な場合は、以下にコメントしてください。ありがとう。
希望する出力に近いもの:
;with cpt
AS
(
Select 'abc' as cptname
)
,sys
AS
(
Select 'a' as "system"
union all Select 'b' as "system"
union all Select 'Manual' as "system"
)
,org
AS
(
Select 'Coll' AS "orgRole"
union all Select 'Lega'
)
SELECT
LTRIM(RTRIM(c1.cptname)) as "orgHeader/orgCode",
LTRIM(RTRIM(c1.cptname)) as "orgHeader/longName",
LTRIM(RTRIM(c1.cptname)) as "orgHeader/shortName",
'Branch' as "orgRole",
s."externalCodes"
FROM
cpt as c1
CROSS APPLY
(SELECT
s."system" as "externalCode/system",
LTRIM(RTRIM(c1.cptname)) as "externalCode/extCode"
FROM sys as s
FOR XML PATH(''), TYPE, ELEMENTS
)s(externalCodes)
UNION ALL
SELECT
LTRIM(RTRIM(c1.cptname)) +'.' as "orgHeader/orgCode",
LTRIM(RTRIM(c1.cptname)) +'.' as "orgHeader/longName",
LTRIM(RTRIM(c1.cptname)) +'.' as "corgHeader/shortName",
o.orgRole as "orgRole",
null
FROM
cpt as c1
CROSS APPLY
(SELECT org.orgRole
FROM org
FOR XML PATH(''), TYPE, ELEMENTS
) as o(orgRole)
FOR XML PATH('organisation'), root ('collection')
そのための出力:
<collection>
<organisation>
<orgHeader>
<orgCode>abc</orgCode>
<longName>abc</longName>
<shortName>abc</shortName>
</orgHeader>
<orgRole>Branch</orgRole>
<externalCodes>
<externalCode>
<system>a</system>
<extCode>abc</extCode>
</externalCode>
<externalCode>
<system>b</system>
<extCode>abc</extCode>
</externalCode>
<externalCode>
<system>Manual</system>
<extCode>abc</extCode>
</externalCode>
</externalCodes>
</organisation>
<organisation>
<orgHeader>
<orgCode>abc.</orgCode>
<longName>abc.</longName>
<shortName>abc.</shortName>
</orgHeader>
<orgRole>
<orgRole>Coll</orgRole>
<orgRole>Lega</orgRole>
</orgRole>
</organisation>
</collection>
親タグorgRole
を削除する必要があるとのことですが、私たちは最終的なソリューションに近づいていますが、まだそこにはありません。 FOR XML EXPLICIT
についてアイデアがあります
;with cpt
AS
(
Select 'abc' as cptname
)
,sys
AS
(
Select 'a' as "system"
union all Select 'b' as "system"
union all Select 'Manual' as "system"
)
,org
AS
(
Select 'Coll' AS "orgRole"
union all Select 'Lega'
)
,cte_source
AS
(
SELECT LTRIM(RTRIM(c1.cptname)) as cptname,
'Branch' as orgRole,
s.system,
s.extcode
FROM
cpt as c1
CROSS APPLY
(SELECT
s.system ,
LTRIM(RTRIM(c1.cptname)) as extCode
FROM sys as s
)s(system,extCode)
UNION ALL
SELECT
LTRIM(RTRIM(c1.cptname)) +'.' ,
o.orgRole,
null,
null
FROM
cpt as c1
CROSS APPLY
(SELECT org.orgRole
FROM org
) as o(orgRole)
)
--select * from cte_source
SELECT 1 as Tag
,NULL as Parent
,NULL as [collection!1!]
,NULL as [organisation!2!]
,NULL as [orgHeader!3!]
,NULL as [orgHeader!3!orgCode!ELEMENT]
,NULL as [orgHeader!3!longName!ELEMENT]
,NULL as [orgHeader!3!shortName!ELEMENT]
,NULL as [orgRole!4!]
,NULL as [externalCodes!5!]
,NULL as [externalCode!6!system!ELEMENT]
,NULL as [externalCode!6!extCode!ELEMENT]
UNION ALL
-- for organisation
SELECT DISTINCT
2 as Tag
,1 as Parent
,NULL as [collection!1!]
,NULL as [organisation!2!]
,NULL as [orgHeader!3!]
,c.cptname as [orgHeader!3!orgCode!ELEMENT]
,c.cptname as [orgHeader!3!longName!ELEMENT]
,c.cptname as [orgHeader!3!shortName!ELEMENT]
,NULL as [orgRole!4!]
,NULL as [externalCodes!5!]
,NULL as [externalCode!6!system!ELEMENT]
,NULL as [externalCode!6!extCode!ELEMENT]
FROM
cte_source as c
UNION ALL
--for orgHeader
SELECT DISTINCT
3 as Tag
,2 as Parent
,NULL as [collection!1!]
,NULL as [organisation!2!]
,NULL as [orgHeader!3!]
,c.cptname as [orgHeader!3!orgCode!ELEMENT]
,c.cptname as [orgHeader!3!longName!ELEMENT]
,c.cptname as [orgHeader!3!shortName!ELEMENT]
,NULL as [orgRole!4!]
,NULL as [externalCodes!5!]
,NULL as [externalCode!6!system!ELEMENT]
,NULL as [externalCode!6!extCode!ELEMENT]
FROM
cte_source as c
UNION ALL
--for orgRole
SELECT DISTINCT
4 as Tag
,2 as Parent
,NULL as [collection!1!]
,NULL as [organisation!2!]
,NULL as [orgHeader!3!]
,c.cptname as [orgHeader!3!orgCode!ELEMENT]
,c.cptname as [orgHeader!3!longName!ELEMENT]
,c.cptname as [orgHeader!3!shortName!ELEMENT]
,c.orgRole as [orgRole!4!]
,NULL as [externalCodes!5!]
,NULL as [externalCode!6!system!ELEMENT]
,NULL as [externalCode!6!extCode!ELEMENT]
FROM
cte_source as c
UNION ALL
--for externalCodes
SELECT DISTINCT
5 as Tag
,2 as Parent
,NULL as [collection!1!]
,NULL as [organisation!2!]
,NULL as [orgHeader!3!]
,c.cptname as [orgHeader!3!orgCode!ELEMENT]
,c.cptname as [orgHeader!3!longName!ELEMENT]
,c.cptname as [orgHeader!3!shortName!ELEMENT]
,NULL as [orgRole!4!]
,NULL as [externalCodes!5!]
,NULL as [externalCode!6!system!ELEMENT]
,NULL as [externalCode!6!extCode!ELEMENT]
FROM
cte_source as c
UNION ALL
--for externalCode
SELECT DISTINCT
6 as Tag
,5 as Parent
,NULL as [collection!1!]
,NULL as [organisation!2!]
,NULL as [orgHeader!3!]
,c.cptname as [orgHeader!3!orgCode!ELEMENT]
,c.cptname as [orgHeader!3!longName!ELEMENT]
,c.cptname as [orgHeader!3!shortName!ELEMENT]
,NULL as [orgRole!4!]
,NULL as [externalCodes!5!]
,c.system as [externalCode!6!system!ELEMENT]
,c.extCode as [externalCode!6!extCode!ELEMENT]
FROM
cte_source as c
ORDER BY
[organisation!2!]
,[orgHeader!3!orgCode!ELEMENT]
--,[orgRole!4!]
,[externalCode!6!system!ELEMENT]
,[externalCode!6!extCode!ELEMENT]
FOR XML EXPLICIT
そのための出力:
<collection>
<organisation>
<orgHeader>
<orgCode>abc</orgCode>
<longName>abc</longName>
<shortName>abc</shortName>
</orgHeader>
<orgRole>Branch</orgRole>
<externalCodes>
<externalCode>
<system>a</system>
<extCode>abc</extCode>
</externalCode>
<externalCode>
<system>b</system>
<extCode>abc</extCode>
</externalCode>
<externalCode>
<system>Manual</system>
<extCode>abc</extCode>
</externalCode>
</externalCodes>
</organisation>
<organisation>
<orgHeader>
<orgCode>abc.</orgCode>
<longName>abc.</longName>
<shortName>abc.</shortName>
</orgHeader>
<orgRole>Coll</orgRole>
<orgRole>Lega</orgRole>
<externalCodes>
<externalCode />
</externalCodes>
</organisation>
</collection>
小さな注意:対応する列にnull値がある場合でも、externalCodes/externalCode
は(nullで)表示されます。
2つの変数を使用できます。1つはXMLの最初の部分を格納するためのもので、もう1つは2番目の部分を格納するためのものです。次に、プレフィックス<collection>
およびサフィックス `'として追加します
declare @cpt table
(
cptname varchar(10)
)
insert into @cpt(cptname)
values('abc')
declare @sys table
(
system varchar(10)
)
insert into @sys(system)
values('a'),('b'),('Manual')
declare @org table
(
orgRole varchar(10)
)
insert into @org(orgRole)
values('Coll'),('Lega')
declare @nvc_o1 nvarchar(max)=N''
,@nvc_o2 nvarchar(max)=N''
SET @nvc_o1 = (
SELECT
LTRIM(RTRIM(c1.cptname)) as "orgHeader/orgCode",
LTRIM(RTRIM(c1.cptname)) as "orgHeader/longName",
LTRIM(RTRIM(c1.cptname)) as "orgHeader/shortName",
'Branch' as "orgRole",
(
SELECT system, extCode from
(
Select 'a' AS 'system', LTRIM(RTRIM(c1.cptname)) AS
'extCode'
UNION ALL
Select 'b' AS 'system', LTRIM(RTRIM(c1.cptname)) AS
'extCode'
UNION ALL
Select 'Manual' AS 'system', LTRIM(RTRIM(c1.cptname)) AS
'extCode'
) a
FOR XML PATH('externalCode'), TYPE, ELEMENTS,Root('externalCodes')
)
from @cpt as c1
FOR XML PATH(''), root ('organisation')
)
SET @nvc_o2 = (
SELECT
LTRIM(RTRIM(c1.cptname))+'.' as "orgHeader/orgCode",
LTRIM(RTRIM(c1.cptname))+'.' as "orgHeader/longName",
LTRIM(RTRIM(c1.cptname))+'.' as "orgHeader/shortName",
(
SELECT orgRole from @org
FOR XML PATH(''), TYPE, ELEMENTS
)
from @cpt as c1
FOR XML PATH(''), root ('organisation')
)
select CAST(N'<collection>' AS NVARCHAR(MAX))
+ @nvc_o1
+ @nvc_o2
+ CAST(N'</collection>' AS NVARCHAR(MAX))
この出力:
<collection>
<organisation>
<orgHeader>
<orgCode>abc</orgCode>
<longName>abc</longName>
<shortName>abc</shortName>
</orgHeader>
<orgRole>Branch</orgRole>
<externalCodes>
<externalCode>
<system>a</system>
<extCode>abc</extCode>
</externalCode>
<externalCode>
<system>b</system>
<extCode>abc</extCode>
</externalCode>
<externalCode>
<system>Manual</system>
<extCode>abc</extCode>
</externalCode>
</externalCodes>
</organisation>
<organisation>
<orgHeader>
<orgCode>abc.</orgCode>
<longName>abc.</longName>
<shortName>abc.</shortName>
</orgHeader>
<orgRole>Coll</orgRole>
<orgRole>Lega</orgRole>
</organisation>
</collection>
後で追加
bcpでエクスポートするには:[test].[dbo].[test_xml]
これは、コードを内部に配置するストアドプロシージャです。
declare @sql nvarchar(4000)
select @sql = N'bcp.exe "EXEC [test].[dbo].[test_xml]" queryout "d:\csv\comm.txt" -c -t, -T -S'+ @@servername
exec master..xp_cmdshell @sql