Introduzione al Data Modeling in Snowflake
Nuno Rocha
Director of Engineering





ALTER TABLE students RENAME TO dim_students;
ALTER TABLE classes RENAME TO dim_classes;
ALTER TABLE schools RENAME TO dim_schools;
dim_date per salvare date chiave fisse legate alle iscrizioni degli studenti:CREATE OR REPLACE TABLE dim_date (
date_id NUMBER(10,0) PRIMARY KEY,
year NUMBER(4,0),
semester VARCHAR(255)
);
CREATE OR REPLACE TABLE fact_enrollments (
enrollment_id NUMBER(10,0) PRIMARY KEY,
student_id NUMBER(10,0),
class_id NUMBER(10,0),
date_id NUMBER(10,0),
FOREIGN KEY (student_id) REFERENCES dim_students(student_id),
FOREIGN KEY (class_id) REFERENCES dim_classes(class_id),
FOREIGN KEY (date_id) REFERENCES dim_date(date_id)
);

SELECT name,
class_name
FROM fact_enrollments
JOIN dim_students -- Join per ottenere i nomi degli studenti
ON fact_enrollments.student_id = dim_students.student_id
JOIN dim_classes -- Join per ottenere i nomi dei corsi
ON fact_enrollments.class_id = dim_classes.class_id
JOIN dim_schools -- Join per filtrare per la scuola "Science"
ON dim_classes.school_id = dim_schools.school_id
JOIN dim_date -- Join per limitare i dati all'anno 2023
ON fact_enrollments.date_id = dim_date.date_id
WHERE dim_schools.school_name = 'Science'
AND dim_date.year = 2023;
ALTER TABLE: comando SQL per modificare la struttura di un'entità esistenteRENAME TO: comando SQL, usato con ALTER TABLE, per rinominare un'entitàJOIN ON: clausola SQL per unire righe da tabelle, basata su una colonna correlataWHERE: clausola SQL per filtrare record in base a una condizioneAND: operatore logico usato con WHERE per combinare più condizioni-- Modificare un'entità
ALTER TABLE table_name
RENAME TO new_name;
-- Interrogare dati da entità unite, filtrati da condizioni specifiche
SELECT
table_name.column_name,
other_name.*
FROM table_name
JOIN other_table
ON table_name.FK = other_table.PK
WHERE column_name condition value
AND column_name condition value;
Introduzione al Data Modeling in Snowflake