İleri Düzey Ortak Tablo İfadeleri

Snowflake'te Veri İşleme

Jake Roach

Field Data Engineer

Birden çok Ortak Tablo İfadesi tanımlama

Tek bir WITH ifadesiyle birden çok ortak tablo ifadesi tanımlanabilir

$$

  • Keyfi sayıda CTE tanımlanabilir
  • CTE’ler birlikte JOIN edilebilir
  • CTE içinde karmaşık işlemler yapılabilir
  • Bir CTE’nin sonucu başka birinde kullanılabilir
WITH <cte-name> AS (

    <query>

), <another-cte-name> (

    -- Add another query!
    <another-query>
)

-- These CTE's could be JOIN'd 
SELECT ... ;
Snowflake'te Veri İşleme

En başarılı dersler

WITH active_courses AS (
    SELECT
        id,
        course_name,
        teacher_name
    FROM courses
    WHERE is_active

), course_avgs ( SELECT course_id, AVG(grade) AS avg_grade FROM student_courses GROUP BY course_id )

SELECT
    a.course_name,
    a.teacher_name,
    c.avg_grade
FROM active_courses AS a

-- JOIN these CTEs together
JOIN course_avgs AS c
    ON a.id = c.course_id

ORDER BY avg_grade DESC;

Sorgu daha anlaşılır olur!

Snowflake'te Veri İşleme

En başarılı dersler

Geçici sonuç kümelerinin birleşerek her ders için ortalama puanlar ve öğretmen adlarını oluşturması

Snowflake'te Veri İşleme

Kıdemli öğretmenler

WITH active_courses AS (
    SELECT
        id,
        course_name,
        teacher_name,
        teacher_tenure
    FROM courses

    -- JOIN the teachers table to the courses 
    -- table to get teacher_tenure
    JOIN teachers 
        ON courses.teacher_id = teachers.id

    WHERE is_active
), 
...
...
), course_avgs (
    SELECT
        course_id,
        AVG(grade) AS avg_grade
    FROM student_courses
    GROUP BY course_id
)

SELECT a.teacher_name, a.teacher_tenure MAX(c.avg_grade) AS highest_grade FROM active_courses AS a JOIN course_avgs AS c ON a.id = c.course_id GROUP BY a.teacher_name, a.teacher_tenure;
Snowflake'te Veri İşleme

Kıdemli öğretmenler

Öğretmen kıdemi ve en yüksek ders ortalamasını bulan sorgunun sonuç kümesi

Snowflake'te Veri İşleme

Haydi pratik yapalım!

Snowflake'te Veri İşleme

Preparing Video For Download...