Mam zestaw danych w tabeli o nazwie BWHourlyReadings
, na przykład:Jak połączyć/scalić kolumny z dwóch wyników zapytania SQL?
ServiceID Hour InputOctets OutputOctets
========= ==== =========== =================
27222 1 383088 804249
27222 2 270529 688683
27222 3 247251 290124
... up to 24 hours of data
27222 24 236053 239165
28900 1 883011 914249
28900 3 444251 891124
... up to 24 hours of data
28900 24 123053 452165
Dla każdego dnia są do 24 odczytów na ServiceID
.
Mam miarę dwa oddzielnePIVOT
zapytania, po jednym dla kolumny InputOctets
i jeden dla kolumny OutputOctets
(tylko jeden pokazano tu na zwięzłość):
-- Replace HourXIn with HourXOut for OutputOctets
SELECT ServiceID, [1] AS 'Hour1In', [2] AS 'Hour2In', [3] AS 'Hour3In', ...
FROM
(
SELECT
ServiceID,
Hour,
TotalInputOctets -- Other query has OutputOctets here instead
FROM
BWHourlyReadings
) AS bw
PIVOT
(
MAX(TotalInputOctets) -- Other query has OutputOctets here instead
FOR [Hour] IN ([1], [2], [3], ... [24])
) AS pvt
Daje mi InputOctets
i OutputOctets
w dwa niezależne zestawy wyników, na przykład:
wynik PIVOT
zapytanie o InputOctets
:
ServiceID Hour1In Hour2In Hour3In . Hour24In
========= ======= ======= ======= ========
27222 383088 270529 247251 236053
28900 883011 0 444251 123053
Wynik PIVOT
zapytanie na OutputOctets
:
ServiceID Hour1Out Hour2Out Hour3Out .. Hour24Out
========= ======== ======== ======== ========
27222 804249 688683 290124 239165
28900 914249 0 891124 452165
muszę przedstawić sprawozdanie takiego:
ServiceID Hour1In Hour1Out Hour2In Hour2Out Hour3In Hour3Out .. Hour24In Hour24Out
========= ======= ======== ======= ======== ======= ======== ======= ========
27222 383088 804249 270529 688683 247251 290124 236053 239165
28900 883011 914249 0 0 444251 891124 123053 452165
Jak scalić dwa wyników zapytania w celu uzyskania raportu powyżej?
Aktualizacja:
mam zaktualizowane dane w żądanym formacie raportu, aby dopasować dane w przykładzie tabeli źródłowej. Moje przeprosiny za zamieszanie.
To będzie po prostu dać mi łączny wynik, jeden po drugim . Muszę scalić dwa zbiory kolumn w wyniku. – Kev