Wersja, w której nie ma elementów dynamicznych. Jeśli masz nazwy kolumn, których nie można użyć jako nazw elementów w XML, to się nie powiedzie.
select T2.N.value('local-name(.)', 'nvarchar(128)') as [Key],
T2.N.value('text()[1]', 'nvarchar(max)') as Value
from (select *
from TableA
for xml path(''), type) as T1(X)
cross apply T1.X.nodes('/*') as T2(N)
Próbka robocza:
declare @T table
(
Column1 varchar(10),
Column2 varchar(10),
Column3 varchar(10)
)
insert into @T values('V1','V2','V3')
select T2.N.value('local-name(.)', 'nvarchar(128)') as [Key],
T2.N.value('text()[1]', 'nvarchar(max)') as Value
from (select *
from @T
for xml path(''), type) as T1(X)
cross apply T1.X.nodes('/*') as T2(N)
Wynik:
Key Value
-------------------- -----
Column1 V1
Column2 V2
Column3 V3
Aktualizacja
W przypadku zapytania z więcej niż jedną tabelą możesz użyć for xml auto
aby uzyskać nazwy tabel w XML. Zauważ, że jeśli użyjesz aliasu dla nazw tabel w zapytaniu, zamiast tego otrzymasz alias.
select X2.N.value('local-name(..)', 'nvarchar(128)') as TableName,
X2.N.value('local-name(.)', 'nvarchar(128)') as [Key],
X2.N.value('text()[1]', 'nvarchar(max)') as Value
from (
-- Your query starts here
select T1.T1ID,
T1.T1Col,
T2.T2ID,
T2.T2Col
from T1
inner join T2
on T1.T1ID = T2.T1ID
-- Your query ends here
for xml auto, elements, type
) as X1(X)
cross apply X1.X.nodes('//*[text()]') as X2(N)