SQL Server'da Sorgu Performansını İyileştirme
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 | ... |
| ... | ... | ... | ... |
Kapsayıcı LEFT OUTER JOIN

Ayrık 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: varlığı kontrol eder
EXCEPT: yokluğu kontrol eder
Avantajlar
Dezavantaj
SELECT ifadesindeki sütun sayısı ve sırası sorgular arasında aynı olmalıdırEXISTS: varlığı kontrol eder
NOT EXISTS: yokluğu kontrol eder
Avantajlar
Dezavantaj
IN: varlığı kontrol eder
NOT IN: yokluğu kontrol eder
Avantaj
Dezavantajlar
NOT IN hiç sonuç döndürmeyebilirINNER JOIN: varlığı kontrol eder
ayrık LEFT OUTER JOIN: yokluğu kontrol eder
Avantaj
Dezavantaj
LEFT OUTER JOIN için IS NULL WHERE koşulu ekleme gerekliliğiSQL Server'da Sorgu Performansını İyileştirme