Snowflake ile Veri Modellemesine Giriş
Nuno Rocha
Director of Engineering



ALTER TABLE classes
ADD FOREIGN KEY (school_id) REFERENCES schools(school_id);


CREATE OR REPLACE TABLE enrollments ( -- Eşsiz bir tanımlayıcıyla yeni bir varlık oluştur enrollment_id NUMBER(10,0) PRIMARY KEY-- Varlığın özniteliklerini ekle year NUMBER(4,0), semester VARCHAR(255)-- Diğer varlıklarla ilişkileri ekle FOREIGN KEY (student_id) REFERENCES students(student_id), FOREIGN KEY (class_id) REFERENCES classes(class_id));


SELECT students.name
FROM students;

SELECT students.name
FROM students
JOIN enrollments
ON students.student_id = enrollments.student_id;

SELECT students.name
FROM students
JOIN enrollments
ON students.student_id = enrollments.student_id
WHERE enrollments.year = '2023';

SELECT students.name,
classes.class_name
FROM students
JOIN enrollments
ON students.student_id = enrollments.student_id
JOIN classes
ON enrollments.class_id = classes.class_id
WHERE enrollments.year = '2023';

SELECT students.name,
classes.class_name
FROM students
JOIN enrollments
ON students.student_id = enrollments.student_id
JOIN classes
ON enrollments.class_id = classes.class_id
JOIN schools
ON classes.department_id = schools.school_id
WHERE enrollments.year = '2023'
AND schools.school_name = 'Science';
JOIN ON: İlgili sütuna dayalı olarak tabloları birleştiren SQL ifadesi.
SELECT FROM: Bir tablodan sütunları çeker.JOIN ON: İlgili sütuna göre tabloları birleştirir.WHERE: Kayıtları koşula göre filtreler.AND: WHERE ile birden çok koşulu birleştirir.-- Belirli koşullarla birleştirilmiş varlıklardan veri sorgulama
SELECT column_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ş