作为一个例子,简化我正在做的事情,说我有以下表格:
declare @elements table (id int, name nvarchar(20))
insert into @elements (id, name) values (1, 'FirstName')
insert into @elements (id, name) values (2, 'Surname')
insert into @elements (id, name) values (3, 'Address')
declare @values table (id int, value nvarchar(20), elementId int)
insert into @values (id, value, elementId) values (1, 'XXX', 1)
insert into @values (id, value, elementId) values (2, 'YYY', 2)
insert into @values (id, value, elementId) values (3, 'ZZZ', 3)
它简单地定义了一个可以是动态的元素名称表,对其定义了一个值表。
我想要的是以下面的形式生成XML,其中@elements表的值成为元素名称,@ value表的值成为值。
<Customer>
<FirstName>XXX</FirstName>
<Surname>YYY</Surname>
<Address>ZZZ<Address>
</Customer>
然而,到目前为止我对for xml
的努力并不是那么顺利:
select e.name, v.value from @elements e
inner join @values v on v.elementId = e.id
for xml path(''), root('customer')
返回
<customer>
<name>FirstName</name>
<value>XXX</value>
<name>Surname</name>
<value>YYY</value>
<name>Address</name>
<value>ZZZ</value>
</customer>
for xml auto
返回
<customer>
<e name="FirstName">
<v value="XXX" />
</e>
<e name="Surname">
<v value="YYY" />
</e>
<e name="Address">
<v value="ZZZ" />
</e>
</customer>
for xml raw
返回
<customer>
<row name="FirstName" value="XXX" />
<row name="Surname" value="YYY" />
<row name="Address" value="ZZZ" />
</customer>
有没有办法可以将列中的值作为元素名称输出?我确定我在这里遗漏了一些显而易见的东西。
答案 0 :(得分:13)
这很好吃但是有效......
select
cast('<' + name + '>' + value + '</' + name + '>' as xml)
from @values v
join @elements e on v.id = e.id
for xml path(''), root('Customer')
---结果---
<Customer>
<FirstName>XXX</FirstName>
<Surname>YYY</Surname>
<Address>ZZZ</Address>
</Customer>
答案 1 :(得分:7)
您正在尝试为可怕的语义数据库(Entity-Attribute-Value)建模。阅读本文至少可以让您开始正确的道路:Best Practices for Semantic Data Modeling for Performance and Scalability
从技术上讲,这是您正在寻找的查询:
select * from (
select name, value
from @values v
join @elements e on v.id = e.id) ve
pivot (max(value)
for name in ([FirstName], [Surname], [Address])) as p
for xml path('Customer')