Introduzione al Data Modeling in Snowflake
Nuno Rocha
Director of Engineering








SELECT
hs.student_key,
ss.student_name
FROM hub_students AS hs
JOIN sat_student AS ss ON hs.student_key = ss.student_key;
LEFT JOIN ON: clausola SQL che unisce tutte le righe dell’entità a sinistra con le corrispondenti della tabella a destra, basandosi su una chiave con ONSELECT
hs.student_key,
ss.student_name
FROM hub_students AS hs
JOIN sat_student AS ss ON hs.student_key = ss.student_key
LEFT JOIN link_enrollment AS le ON hs.student_key = le.student_key
COUNT: funzione aggregata SQL che restituisce il numero di elementi in un gruppo.GROUP BY: clausola SQL per aggregare dati con gli stessi valori.SELECT
hs.student_key,
ss.student_name,
COUNT(le.class_key) AS NumberOfEnrollments
FROM hub_students AS hs
JOIN sat_student AS ss ON hs.student_key = ss.student_key
LEFT JOIN link_enrollment AS le ON hs.student_key = le.student_key
GROUP BY hs.student_key,
ss.student_name
MAX: funzione aggregata SQL che trova il valore più alto di un attributo.SELECT
hs.student_key,
ss.student_name,
COUNT(le.class_key) AS NumberOfEnrollments
MAX(sc.load_date) AS MostRecentEnrollmentDate
FROM hub_students hs
JOIN sat_student ss ON hs.student_key = ss.student_key
LEFT JOIN link_enrollment le ON hs.student_key = le.student_key
LEFT JOIN sat_class sc ON le.class_key = sc.class_key
GROUP BY hs.student_key,
ss.student_name;
SELECT FROM: comando SQL per estrarre colonne da un’entitàJOIN ON: clausola SQL che unisce righe tra entità in base a un attributo correlatoLEFT JOIN ON: unisce tutte le righe dell’entità a sinistra con le corrispondenti della tabella a destra, basandosi su una chiave. Se non c’è corrispondenza, mostra comunque le righe di sinistra con valori vuoti a destraCOUNT: funzione aggregata SQL che restituisce il numero di elementi in un gruppoMAX: funzione aggregata SQL che trova il valore più alto per un attributoGROUP BY: clausola SQL per aggregare dati con gli stessi valoriSELECT column_name,
COUNT(another_column) AS alias_name,
MAX(other_column) AS alias_name
FROM table_name table_alias
-- Merge entities based on their keys
JOIN other_table AS other_alias
ON table_alias.FK = other_alias.PK
LEFT JOIN another_table AS another_alias
ON table_alias.FK = other_alias.PK
-- Aggregate data by specific columns
GROUP BY column_name;
Introduzione al Data Modeling in Snowflake