Преобразование XML-данных в табличную и XML-форму в SQL Server 2005

#xml #sql-server-2005 #xquery-sql

#xml #sql-server-2005 #xquery-sql

Вопрос:

Это мой XML

 <ROOMTYPES>
  <ROOMTYPE Id="1" Total="5">
    <ROOMFACILITIES>
      <FID>101</FID>
      <FID>103</FID>
      <FID>105</FID>
    </ROOMFACILITIES>
  </ROOMTYPE>
  <ROOMTYPE Id="2" Total="4">
    <ROOMFACILITIES>
      <FID>108</FID>
      <FID>109</FID>
      <FID>110</FID>
    </ROOMFACILITIES>
  </ROOMTYPE>
</ROOMTYPES>
  

Мне нужно создать XQuery, который отображал бы результат следующим образом

 int int xml
1   5   <FID>101</FID><FID>103</FID><FID>105</FID>
2   4   <FID>108</FID><FID>109</FID><FID>110</FID>
  

Я добрался сюда..

 int int xml
1   5   <FID>101</FID><FID>103</FID><FID>105</FID>
2   4   <FID>101</FID><FID>103</FID><FID>105</FID>
  

используя это

 declare @xmldocument xml;
set @xmldocument =( select RoomTypes from Hotels);

declare @tb table(id int, total int, fid xml);
declare @id int;
set @id=0;
insert into @tb (id, total,fid)

select  
    p.value('../@Id', 'int'),
    p.value('../@Total', 'int'),
    p.query('//ROOMTYPE[@Id=1]/ROOMFACILITIES/FID')

from @xmldocument.nodes('ROOMTYPES/ROOMTYPE/ROOMFACILITIES') n(p)
select * from @tb;
  

Поскольку я жестко запрограммировал @Id = 1, он показывает результат только для первого элемента.

Приветствуется любая помощь…

Ответ №1:

 select  
    p.value('../@Id', 'int'),
    p.value('../@Total', 'int'),
    p.query('FID')
from @xmldocument.nodes('ROOMTYPES/ROOMTYPE/ROOMFACILITIES') n(p)