Manipolazione dei dati in Snowflake
Jake Roach
Field Data Engineer
$$
A volte ci sono valori che non rientrano in un blocco
WHEN ... THEN.
$$
ELSE per coprire questi casiSELECT
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 |
| 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
SELECT todays_date, temperature, CASEWHEN 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;

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