Logica condizionale con istruzioni CASE

Manipolazione dei dati in Snowflake

Jake Roach

Field Data Engineer

Uso di ELSE

$$

A volte ci sono valori che non rientrano in un blocco WHEN ... THEN.

$$

  • Usa ELSE per coprire questi casi
  • Ottimo per gestire edge case
SELECT
    student,
    CASE
        WHEN grade_num = 12 THEN 'Senior'
        WHEN grade_num = 11 THEN 'Junior'
        ...
        ELSE 'Not in HS'  -- Catch others!
    END AS grade
FROM students;
          |   student  |    grade   |
          | ---------- | ---------- |
          |  Viraj     |  Junior    |
          |  Stephanie |  Senior    |
          |  Lewis     |  Not in HS |
Manipolazione dei dati in Snowflake

Valutare una condizione

Operatore Condizione Esempio
= Il valore è uguale a un altro valore column_a = 'value_a'
IN (...) Il valore è in un elenco di valori column_a IN ('value_a', 'value_b')
>, < Il valore è maggiore o minore di un altro column_a > 0
>=, <= Varianti di > e <, includono l'uguaglianza column_a >= 0
BETWEEN Il valore è tra due valori, inclusi column_a BETWEEN 0 AND 10

Questi operatori si combinano con AND, OR o NOT

I CASE in Snowflake sono efficienti perché il DB è column-oriented

Manipolazione dei dati in Snowflake

Classificare le temperature

SELECT
    todays_date,
    temperature,
    CASE

WHEN temperature BETWEEN 70 AND 90 THEN 'Ideal for Swimming'
WHEN temperature >= 50 AND tempreature < 70 THEN 'Perfect for Sports'
WHEN temperature > 32 AND temperature < 50 THEN 'Spring/Fall Temps' WHEN temperature > 0 AND temperature <= 32 THEN 'Winter Weather' ELSE 'Extreme Temperatures'
END AS temperature_description FROM weather;
Manipolazione dei dati in Snowflake

Classificare le temperature

Tabella con i risultati di un CASE che classifica i record per temperatura

Manipolazione dei dati in Snowflake

Combinare condizioni

SELECT
    todays_date,
    temperature,
    status,

CASE WHEN temperature > 70 AND status NOT IN ('Rain', 'Wind') THEN 'Beach'
WHEN temperature BETWEEN 45 AND 70 AND status = 'Sun' THEN 'Sports'
WHEN temperature <= 32 OR status = 'Snow' THEN 'Skiing'
ELSE 'Stay In' END AS activity FROM weather;

Possiamo valutare più colonne in un unico CASE

Manipolazione dei dati in Snowflake

Combinare condizioni

Tabella con i risultati di un CASE che classifica i record per temperatura e stato meteo

Manipolazione dei dati in Snowflake

Passiamo alla pratica !

Manipolazione dei dati in Snowflake

Preparing Video For Download...