Applicare la logica condizionale in Snowflake

Manipolazione dei dati in Snowflake

Jake Roach

Field Data Engineer

Aggregazione con CASE

Le query con CASE possono usare anche funzioni di aggregazione.

  • SUM()
  • AVG()
  • MIN()
  • MAX()
  • ...
  • MODE()

$$

Ricorda di includere GROUP BY!

Struttura di uno statement CASE con aggregazione e raggruppamento

Manipolazione dei dati in Snowflake

Aggregazione con CASE

SELECT
    CASE
        WHEN month_num IN (12, 1, 2) THEN 'Winter'
        WHEN month_num IN (3, 4, 5) THEN 'Spring'
        WHEN month_num in (6, 7, 8) THEN 'Summer'
        ELSE 'Fall'
    END AS season,

AVG(temperature) AS average_temperature, -- Manipulate data with AVG()
year_num FROM weather GROUP BY season, year_num; -- Remember to group by non-aggregated fields
Manipolazione dei dati in Snowflake

Aggregazione con CASE

Risultati di una query che calcola la temperatura media per stagione e anno

Manipolazione dei dati in Snowflake

Aggregare campi con CASE

SELECT
    season,
    AVG(
        CASE
            WHEN season = 'Winter' THEN temperature - 30
            WHEN season IN ('Spring', 'Fall') THEN temperature - 60
            WHEN season = 'Summer' THEN temperature - 75
        END
    ) AS relation_to_average_temperature
FROM weather
GROUP BY season;
Manipolazione dei dati in Snowflake

Aggregare campi con CASE

Tabella che mostra la relazione tra temperatura media e stagione

Manipolazione dei dati in Snowflake

JOIN

SELECT
    ...

    -- Define a CASE statement
    CASE ...

FROM <left_table>

-- JOIN new records to existing table
LEFT JOIN <right_table> 
    ... 
;

Le istruzioni CASE possono usare dati uniti da due tabelle diverse.

  • Usa colonne da più tabelle in un CASE
  • LEFT, RIGHT, INNER, OUTER, ecc.
  • Combina con altre funzioni, incluse quelle di aggregazione

$$

$$

                                          Vediamolo!

Manipolazione dei dati in Snowflake

Determinare l'idoneità ai crediti universitari

SELECT
    students.student_name,
    student_courses.course_name,

-- Evaluate both the student's grade number and grade for the course CASE WHEN students.grade_num = 12 AND student_courses.grade > 90 THEN 'College Credit Eligible' ELSE 'Too Early for College Credit' END AS college_credit_status
FROM student_courses LEFT JOIN students ON student_courses.student_id = students.student_id;
Manipolazione dei dati in Snowflake

Determinare l'idoneità ai crediti universitari

Risultati di una query sulle tabelle JOINed students e student_courses

Manipolazione dei dati in Snowflake

Esercitiamoci!

Manipolazione dei dati in Snowflake

Preparing Video For Download...