Как создать XML с элементом и атрибутом, используя явный XML
Я пытаюсь сгенерировать XML в следующем формате:
<Root>
<Domain>Abc</Domain>
<Name>Xyz</Name>
<Contents>
<Content>
<ID>1</ID>
<Value>Test 1</Value>
<Record ID="1">Test 1</Record>
</Content>
<Content>
<ID>2</ID>
<Value>Test 2</Value>
<Record ID="2">Test 2</Record>
</Content>
</Contents>
</Root>
Мой запрос выглядит следующим образом:
declare @TestTable table (ID int, Value varchar(100))
insert into @TestTable values (1,'Test 1')
insert into @TestTable values (2,'Test 2')
declare @Domain varchar(max)='Abc'
declare @Name varchar(max)='Xyz'
SELECT
1 AS Tag,
NULL AS Parent,
@Domain as 'Root!1!Domain!Element',
@Name as 'Root!1!Name!Element',
NULL as 'Contents!2!Element',
NULL as 'Content!3!ID!Element',
NULL as 'Content!3!Value!Element',
NULL as 'Content!3!Record!Element'
union
SELECT
2 AS Tag,
1 AS Parent,
NULL,NULL,NULL,NULL,NULL,NULL
union
select
3 as Tag,
2 as Parent,
NUll,NUll,NULL,
ID,Value,Value
from @TestTable
FOR XML EXPLICIT
мой запрос не производит тег записи полностью, в настоящее время это
<Record>Test 2</Record>
который должен быть как
<Record ID=2>Test 2</Record>
Я перепробовал все возможности, но не получил тег. Может ли кто-нибудь помочь мне решить эту проблему.
2 ответа
Решение
Я не мог получить ожидаемый вывод из явного XML, вместо этого я использовал путь XML и получил вывод. это мой обновленный запрос
SELECT
@Domain "Domain",
@Name "Name",
(
SELECT
ID "ID",
Value "Value",
(select
ID "@ID",
Value as "text()"
FOR XML PATH('Record'), ELEMENTS, TYPE )
FROM @TestTable
FOR XML PATH ('Content'), TYPE, ROOT('Contents')
)
FOR XML PATH ('Root')
вы можете опубликовать исправление, в котором явно используется xml.
Не забывайте ORDER BY при использовании FOR XML EXPLICIT.
SELECT
1 AS Tag,
NULL AS Parent,
@Domain as 'Root!1!Domain!Element',
@Name as 'Root!1!Name!Element',
NULL as 'Contents!2!Element',
NULL as 'Content!3!ID!Element',
NULL as 'Content!3!Value!Element',
NULL as 'Record!4!ID',
NULL as 'Record!4!'
union
SELECT
2 AS Tag,
1 AS Parent,
@Domain,NULL,NULL,NULL,NULL,NULL, null
union
select
3 as Tag,
2 as Parent,
@Domain,NUll,NULL,
ID,Value,null,null
from @TestTable
union
select
4 as Tag,
3 as Parent,
@Domain,NUll,NULL,
ID,Value,ID,Value
from @TestTable
ORDER BY 'Root!1!Domain!Element','Contents!2!Element','Content!3!ID!Element','Record!4!ID'
FOR XML EXPLICIT