Это простой запрос с использованием функции PIVOT
. Если у вас есть несколько значений, которые, как известно, преобразуются в столбцы, вы можете использовать статическую версию:
create table yourtable
(
cost varchar(10),
rate int
);
insert into yourtable values
('Repair', 12),
('Repair', 223),
('Wear', 1000),
('Wear', 666),
('Fuel', 500),
('Repair', 600),
('Fuel', 450),
('Wear', 400);
select *
from
(
select cost, rate
from yourtable
) x
pivot
(
sum(rate)
for cost in ([Repair], [Wear], [Fuel])
) p;
Если у вас есть неизвестное количество значений, то вы можете использовать динамический SQL для создания динамического центра:
DECLARE @cols AS NVARCHAR(MAX),
@query AS NVARCHAR(MAX)
select @cols = STUFF((SELECT distinct ',' + QUOTENAME(cost)
from yourtable
FOR XML PATH(''), TYPE
).value('.', 'NVARCHAR(MAX)')
,1,1,'')
set @query = 'SELECT ' + @cols + ' from
(
select cost, rate
from yourtable
) x
pivot
(
sum(rate)
for cost in (' + @cols + ')
) p '
execute(@query)
См. SQL Fiddle с демоверсией . Оба будут давать одинаковые результаты.