Gruplanmış verileri filtreleme

Orta Düzey SQL

Jasmin Ludolf

Data Science Content Developer, DataCamp

HAVING

SELECT 
       release_year,
       COUNT(title) AS title_count
FROM films
GROUP BY release_year
WHERE COUNT(title) > 10;
"WHERE" yakınında veya içinde sözdizimi hatası
SATIR 4: WHERE COUNT(title) > 10;
        ^
SELECT 
       release_year,
       COUNT(title) AS title_count
FROM films
GROUP BY release_year
HAVING COUNT(title) > 10;
|release_year|title_count|
|------------|-----------|
|1988        |31         |
|null        |42         |
|2008        |225        |
...
Orta Düzey SQL

Çalıştırma sırası

-- Yazılan kod:

SELECT certification, COUNT(title) AS title_count FROM films WHERE certification IN ('G', 'PG', 'PG-13') GROUP BY certification HAVING COUNT(title) > 500 ORDER BY title_count DESC LIMIT 3;
-- Çalıştırma sırası:

SELECT certification, COUNT(title) AS title_count
FROM films
WHERE certification IN ('G', 'PG', 'PG-13')
GROUP BY certification
HAVING COUNT(title) > 500
ORDER BY title_count DESC
LIMIT 3;
Orta Düzey SQL

HAVING ve WHERE

  • WHERE tekil kayıtları, HAVING ise gruplanmış kayıtları filtreler
  • 2000 yılında hangi filmler yayımlandı?
SELECT title
FROM films
WHERE release_year = 2000;
|title         |
|--------------|
|102 Dalmatians|
|28 Days       |
...
  • Ortalama film süresinin iki saatin üzerinde olduğu yıllar hangileri?
Orta Düzey SQL

HAVING ve WHERE

  • Ortalama film süresinin iki saatin üzerinde olduğu yıllar hangileri?
SELECT release_year
FROM films

GROUP BY release_year
HAVING AVG(duration) > 120;
|release_year|
|------------|
|1954        |
|1959        |
...
Orta Düzey SQL

Haydi pratik yapalım!

Orta Düzey SQL

Preparing Video For Download...