Ich wollte wissen, welcher der beiden folgenden Ansätze schneller ist:
1) Drei COUNT
:
SELECT Approved = (SELECT COUNT(*) FROM dbo.Claims d
WHERE d.Status = 'Approved'),
Valid = (SELECT COUNT(*) FROM dbo.Claims d
WHERE d.Status = 'Valid'),
Reject = (SELECT COUNT(*) FROM dbo.Claims d
WHERE d.Status = 'Reject')
2) SUM
mit FROM
-Klausel:
SELECT Approved = SUM(CASE WHEN Status = 'Approved' THEN 1 ELSE 0 END),
Valid = SUM(CASE WHEN Status = 'Valid' THEN 1 ELSE 0 END),
Reject = SUM(CASE WHEN Status = 'Reject' THEN 1 ELSE 0 END)
FROM dbo.Claims c;
Ich war überrascht, dass der Unterschied so groß ist. Die erste Abfrage mit drei Unterabfragen gibt das Ergebnis sofort zurück, während die zweite Abfrage SUM
18 Sekunden benötigt.
Claims
ist eine Ansicht, die aus einer Tabelle mit ~ 18 Millionen Zeilen auswählt. In der FK-Spalte befindet sich ein Index zu der ClaimStatus
Tabelle, die den Statusnamen enthält.
Warum macht es so einen großen Unterschied, ob ich benutze COUNT
oder SUM
?
Ausführungspläne:
Insgesamt gibt es 12 Status. Diese drei Status gehören zu 7% aller Zeilen.
Dies ist die aktuelle Ansicht, ich bin nicht sicher, ob es relevant ist:
CREATE VIEW [dbo].[Claims]
AS
SELECT
mu.Marketunitname AS MarketUnit,
c.Countryname AS Country,
gsp.Gspname AS GSP,
gsp.Wcmskeynumber AS GspNumber,
sl.Slname AS SL,
sl.Wcmskeynumber AS SlNumber,
m.Modelname AS Model,
m.Salesname AS [Model-Salesname],
s.Claimstatusname AS [Status],
d.Work_order AS [Work Order],
d.Ssn_number AS IMEI,
d.Ssn_out,
Remarks,
d.Claimnumber AS [Claim-Number],
d.Rma_number AS [RMA-Number],
dbo.ToShortDateString(d.Received_Date, 1) AS [Received Date],
Iddata,
Fisl,
Fimodel,
Ficlaimstatus
FROM Tabdata AS d
INNER JOIN Locsl AS sl
ON d.Fisl = sl.Idsl
INNER JOIN Locgsp AS gsp
ON sl.Figsp = gsp.Idgsp
INNER JOIN Loccountry AS c
ON gsp.Ficountry = c.Idcountry
INNER JOIN Locmarketunit AS mu
ON c.Fimarketunit = mu.Idmarketunit
INNER JOIN Modmodel AS m
ON d.Fimodel = m.Idmodel
INNER JOIN Dimclaimstatus AS s
ON d.Ficlaimstatus = s.Idclaimstatus
INNER JOIN Tdefproducttype
ON d.Fiproducttype = Tdefproducttype.Idproducttype
LEFT OUTER JOIN Tdefservicelevel
ON d.Fimaxservicelevel = Tdefservicelevel.Idservicelevel
LEFT OUTER JOIN Tdefactioncode AS ac
ON d.Fimaxactioncode = ac.Idactioncode
Authorized
.
WHERE c.Status = 'Approved' or c.Status = 'Valid' or c.status = 'Reject'
auf die SUM
Variante.
COUNT
Version des Plans verweisen . Können Sie sich dergleichen auf die bearbeitenSUM
Version auf den richtigen Plan zu zeigen?