एक संस्करण जहां कोई गतिशील शामिल नहीं है। यदि आपके पास स्तंभ नाम हैं जो XML में तत्व नामों के रूप में उपयोग करने के लिए अमान्य हैं तो यह विफल हो जाएगा।
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)
एक कामकाजी नमूना:
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)
परिणाम:
Key Value
-------------------- -----
Column1 V1
Column2 V2
Column3 V3
अपडेट करें
एक से अधिक टेबल वाली क्वेरी के लिए आप for xml auto
. का उपयोग कर सकते हैं एक्सएमएल में टेबल नाम प्राप्त करने के लिए। ध्यान दें, यदि आप क्वेरी में तालिका नामों के लिए उपनाम का उपयोग करते हैं तो आपको इसके बजाय उपनाम मिलेगा।
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)