#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)