Dies ist eine einfache Abfrage mit der Funktion PIVOT
. Wenn Sie ein paar Werte haben, die Spalten umgewandelt dafür bekannt sind, dann können Sie eine statische Version verwenden:
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;
Wenn Sie eine unbekannte Anzahl von Werten haben, dann können Sie die dynamische SQL verwenden, um eine dynamische Dreh zu erstellen :
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)
Siehe SQL Fiddle with Demo. Beides wird zu denselben Ergebnissen führen.
Verwenden Sie WHEN anstelle von WHERE innerhalb der CASE-Syntax. Und beende einen CASE mit END oder END CASE. –
Ah, ich habe das geschrieben und habe die Syntax nicht überprüft. Ich werde es reparieren, Prost. – glasnt
Gibt es eine Möglichkeit, hartcodierte Spaltennamen zu vermeiden? Wenn jemand eine Zeile namens "Bremsen" hinzufügt, muss die Abfrage neu geschrieben werden? Der PIVOT-Ansatz ist generischer, aber nicht so einfach. – Muxecoid