Migliorare le prestazioni delle query in 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 | ... |
| ... | ... | ... | ... |
Inclusivo LEFT OUTER JOIN

Esclusivo 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: verifica la presenza
EXCEPT: verifica l’assenza
Vantaggi
Svantaggio
SELECT devono coincidere tra le queryEXISTS: verifica la presenza
NOT EXISTS: verifica l’assenza
Vantaggi
Svantaggio
IN: verifica la presenza
NOT IN: verifica l’assenza
Vantaggio
Svantaggi
NOT IN gestisce i null nella sottoqueryINNER JOIN: verifica la presenza
LEFT OUTER JOIN esclusivo: verifica l’assenza
Vantaggio
Svantaggio
WHERE IS NULL con il LEFT OUTER JOIN esclusivoMigliorare le prestazioni delle query in SQL Server