Filtreleme ve sıralama

SQL ile Veri Odaklı Karar Verme

Tim Verdonck

Professor Statistics and Data Science

WHERE

İtalya’daki tüm müşterileri seçin:

SELECT *
FROM customers
WHERE country = 'Italy';
|customer_id | name              | country | gender | date_of_birth | date_account_start|
|------------|-------------------|---------|--------|---------------|-------------------|
| 53         | Teresio Panicucci | Italy   | male   | 1999-07-21    | 2018-11-06        |
| 54         | Demetrio Palermo  | Italy   | male   | 1997-10-10    | 2018-10-17        |
| 55         | Facino Milano     | Italy   | male   | 1973-05-23    | 2018-01-02        |
SQL ile Veri Odaklı Karar Verme

WHERE koşulundaki işleçler

  • Karşılaştırma işleçleri:
    • Eşit =
    • Eşit değil <>
    • Küçük <
    • Küçük veya eşit <=
    • Büyük >
    • Büyük veya eşit >=
  • BETWEEN işleci
  • IN işleci
  • IS NULL ve IS NOT NULL işleçleri
SQL ile Veri Odaklı Karar Verme

Örnek karşılaştırma işleçleri

Türü Drama olmayan movies satırlarının tüm sütunlarını seçin.

SELECT *
FROM movies
WHERE genre <> 'Drama';

Kiralama ücreti 2 veya daha büyük olan movies satırlarının tüm sütunlarını seçin.

SELECT *
FROM movies
WHERE renting_price >= 2;
SQL ile Veri Odaklı Karar Verme

Örnek: BETWEEN işleci

Hesap açılış tarihi 2018-01-01 ile 2018-09-30 arasında olan customers satırlarının tüm sütunlarını seçin.

SELECT *
FROM customers
WHERE date_account_start BETWEEN '2018-01-01' AND '2018-09-30';
SQL ile Veri Odaklı Karar Verme

Örnek: IN işleci

Uyrukları ABD veya Avustralya olan tüm aktörleri seçin.

SELECT *
FROM actors
WHERE nationality IN ('USA', 'Australia')
SQL ile Veri Odaklı Karar Verme

Örnek: NULL işleci

renting tablosunda rating değeri NULL olan tüm sütunları seçin.

SELECT *
FROM renting
WHERE rating IS NULL

renting tablosunda rating değeri NULL olmayan tüm sütunları seçin.

SELECT *
FROM renting
WHERE rating IS NOT NULL
SQL ile Veri Odaklı Karar Verme

Mantıksal işleçler AND

Ülkesi İtalya _VE_ 2018-01-01 ile 2018-09-30 arasında hesap açan müşterilerin adını ve hesap açılış tarihini seçin.


SELECT name, date_account_start
FROM customers
WHERE country = 'Italy'
AND date_account_start BETWEEN '2018-01-01' AND '2018-09-30';

| name | date_account_start | |--------------------|--------------------| | Facino Milano | 2018-01-02 | | Mario Lettiere | 2018-01-30 | | Rocco Buccho | 2018-02-27 | | Cristoforo Mancini | 2018-01-12 |
SQL ile Veri Odaklı Karar Verme

Mantıksal işleçler OR

Ülkesi İtalya VEYA 2018-01-01 ile 2018-09-30 arasında hesap açan müşterilerin adını ve hesap açılış tarihini seçin.

SELECT name, date_account_start
FROM customers
WHERE country = 'Italy'
OR date_account_start BETWEEN '2018-01-01' AND '2018-09-30';
| name                  | country | date_account_start |
|-----------------------|-------- |--------------------|
| Rowanne Couperus      | Belgium | 2018-08-26         |
| Annelous Sneep        | Belgium | 2018-05-12         |
| Jaëla van den Dolder  | Belgium | 2018-02-08         |
| ...                   | ...     | ...                |
SQL ile Veri Odaklı Karar Verme

ORDER BY

Sorgu sonuçlarını puana göre sıralayın.

SELECT *
FROM renting
WHERE rating IS NOT NULL
ORDER BY rating;
| renting_id | customer_id | movie_id | rating | date_renting |
|------------|-------------|----------|--------|--------------|
| 552        | 28          | 56       | 1      | 2017-03-27   |
| 558        | 41          | 19       | 3      | 2019-01-13   |
| 444        | 120         | 59       | 3      | 2018-08-10   |
| 200        | 86          | 46       | 3      | 2018-08-26   |
| 234        | 104         | 28       | 4      | 2018-10-04   |
SQL ile Veri Odaklı Karar Verme

ORDER BY ... DESC

Sorgu sonuçlarını puana göre azalan sırada sıralayın.

SELECT *
FROM renting
WHERE rating IS NOT NULL
ORDER BY rating DESC;
| renting_id | customer_id | movie_id | rating | date_renting |
|------------|-------------|----------|--------|--------------|
| 243        | 7           | 5        | 10     | 2019-01-11   |
| 18         | 36          | 39       | 10     | 2019-03-20   |
| 396        | 7           | 40       | 10     | 2018-09-11   |
| 487        | 61          | 48       | 10     | 2017-08-14   |
| 476        | 78          | 42       | 10     | 2018-07-04   |
SQL ile Veri Odaklı Karar Verme

Hadi pratik yapalım!

SQL ile Veri Odaklı Karar Verme

Preparing Video For Download...