Następujące zapytanie zwraca poprawny wynik, ale jak uzyskać ten sam wynik szybciej?Najszybszy sposób podsumowania sprzedaży w oparciu o dzisiaj, w tym tygodniu, w tym miesiącu, w tym kwartale bieżącego roku?
Celem jest wydrukowanie tabeli śledzenia postępów sprzedawców poprzez podsumowanie ich sprzedaży dzisiaj, w tym tygodniu, miesiącu i kwartale.
SellerID Today ThisWeek ThisMonth ThisQuarter
----------- --------------------- --------------------- --------------------- ---------------------
1 400,00 700,00 900,00 900,00
2 950,00 1850,00 2650,00 2650,00
Moje zapytanie:
CREATE TABLE #sales(
[Price] MONEY,
[Date] DATE,
[SellerID] INT
)
INSERT INTO #sales VALUES
(100, '2012-01-01', 1),
(200, '2012-04-01',1),
(300, '2012-04-23',1),
(400, '2012-04-27',1),
(700, '2012-01-01', 2),
(700, '2012-01-02', 2),
(800, '2012-04-01',2),
(900, '2012-04-23',2),
(950, '2012-04-27',2)
SELECT
SellerID AS SellerID,
SUM(CASE WHEN [Date] >= DATEADD(DAY, DATEDIFF(DAY, 0, GETDATE()),0) THEN [Price] END) AS Today,
SUM(CASE WHEN [Date] >= DATEADD(WEEK, DATEDIFF(WEEK, 0, GETDATE()), 0) THEN [Price] END) AS ThisWeek,
SUM(CASE WHEN [Date] >= DATEADD(MONTH, DATEDIFF(MONTH, 0, GETDATE()), 0) THEN [Price] END) AS ThisMonth,
SUM(CASE WHEN [Date] >= DATEADD(QUARTER, DATEDIFF(QUARTER, 0, GETDATE()), 0) THEN [Price] END) AS ThisQuarter
FROM #sales
WHERE DATEPART(YEAR, [Date]) = DATEPART(YEAR, GETDATE())
GROUP BY SellerID
Podczas wykonywania tego samego zapytania o większej tabeli to robi się dość powoli. Po prostu usunięcie instrukcji CASE skraca czas wykonania o prawie 50%.
Jak osiągnąć ten sam rezultat szybciej i efektywniej?
Dopóki twoja kolumna '[Data]' jest indeksowana, myślę, że masz już najbardziej wydajne rozwiązanie do wysyłania zapytań o dane transakcyjne. Jeśli trafisz na problemy z wydajnością, możesz chcieć rozszerzyć magazynowanie danych. – GarethD
Tak, jest indeksowany. Jesteśmy na SQL Azure, który niestety jest obecnie nieco ograniczony. Myślę też, że byłoby to lepsze podejście (+1). –