Snowflake ile Veri Modellemesine Giriş
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 tablosunu oluşturma: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 -- Öğrenci adlarını almak için birleştirme
ON fact_enrollments.student_id = dim_students.student_id
JOIN dim_classes -- Ders adlarını almak için birleştirme
ON fact_enrollments.class_id = dim_classes.class_id
JOIN dim_schools -- 'Science' okuluna göre filtrelemek için birleştirme
ON dim_classes.school_id = dim_schools.school_id
JOIN dim_date -- Veriyi 2023 yılıyla sınırlamak için birleştirme
ON fact_enrollments.date_id = dim_date.date_id
WHERE dim_schools.school_name = 'Science'
AND dim_date.year = 2023;
ALTER TABLE: Mevcut bir varlığın yapısını değiştiren SQL komutuRENAME TO: ALTER TABLE ile kullanılan, bir varlığı yeniden adlandıran SQL komutuJOIN ON: İlişkili bir sütuna dayalı olarak tabloları birleştiren SQL ifadesiWHERE: Koşula göre kayıtları filtreleyen SQL ifadesiAND: WHERE ile birden çok koşulu birleştiren mantıksal işlemci-- Bir varlığı değiştirme
ALTER TABLE table_name
RENAME TO new_name;
-- Belirli koşullara göre birleştirilmiş varlıklardan sorgulama
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;
Snowflake ile Veri Modellemesine Giriş