Meningkatkan Kinerja Kueri di SQL Server
Dean Smith
Founder, Atamai Analytics
SELECT c.CustomerID
,c.CompanyName
,o.OrderID
,o.OrderDate
,o.ShippedDate
,o.Freight
FROM Customers c
INNER JOIN Orders o
ON c.CustomerID = o.CustomerID
| CustomerID | CompanyName | OrderID | ... |
|---|---|---|---|
| VINET | Vins et alcools Chevalier | 10248 | ... |
| HANAR | Hanari Carnes | 10250 | ... |
| VICTE | Victuailles en stock | 10251 | ... |
| SUPRD | Suprêmes délices | 10252 | ... |
| ... | ... | ... | ... |
Inklusif LEFT OUTER JOIN

Eksklusif LEFT OUTER JOIN

SELECT c.CustomerID
,c.CompanyName
,o.OrderID
,o.OrderDate
,o.ShippedDate
,o.Freight
FROM Customers c
LEFT OUTER JOIN Orders o
ON c.CustomerID = o.CustomerID
WHERE o.CustomerID IS NULL
| CustomerID | CompanyName | OrderID | ... |
|---|---|---|---|
| FISSA | FISSA Fabrica Inter. Salchichas S.A. | NULL | ... |
| PARIS | Paris spécialités | NULL | ... |
INTERSECT: memeriksa keberadaan
EXCEPT: memeriksa ketiadaan
Kelebihan
Kekurangan
SELECT harus sama antar kueriEXISTS: memeriksa keberadaan
NOT EXISTS: memeriksa ketiadaan
Kelebihan
Kekurangan
IN: memeriksa keberadaan
NOT IN: memeriksa ketiadaan
Kelebihan
Kekurangan
NOT IN menangani null di subkueriINNER JOIN: memeriksa keberadaan
LEFT OUTER JOIN eksklusif: memeriksa ketiadaan
Kelebihan
Kekurangan
WHERE IS NULL pada LEFT OUTER JOIN eksklusifMeningkatkan Kinerja Kueri di SQL Server