Pengantar Pemodelan Data di 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 untuk menyimpan tanggal tetap terkait pendaftaran siswa: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 untuk mendapatkan nama siswa
ON fact_enrollments.student_id = dim_students.student_id
JOIN dim_classes -- Join untuk mendapatkan nama kelas
ON fact_enrollments.class_id = dim_classes.class_id
JOIN dim_schools -- Join untuk memfilter sekolah 'Science'
ON dim_classes.school_id = dim_schools.school_id
JOIN dim_date -- Join untuk membatasi data ke tahun 2023
ON fact_enrollments.date_id = dim_date.date_id
WHERE dim_schools.school_name = 'Science'
AND dim_date.year = 2023;
ALTER TABLE: Perintah SQL untuk mengubah struktur entitas yang adaRENAME TO: Perintah SQL, digunakan dengan ALTER TABLE, untuk mengganti nama entitasJOIN ON: Klausa SQL untuk menggabungkan baris dari tabel berdasarkan kolom terkaitWHERE: Klausa SQL untuk memfilter catatan berdasarkan kondisiAND: Operator logika pada klausa WHERE untuk menggabungkan beberapa kondisi-- Mengubah sebuah entitas
ALTER TABLE table_name
RENAME TO new_name;
-- Mengquery data dari entitas yang di-join dan difilter kondisi tertentu
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;
Pengantar Pemodelan Data di Snowflake