Ortak Tablo İfadeleri

Snowflake'te Veri İşleme

Jake Roach

Field Data Engineer

Ortak Tablo İfadeleri

Ortak Tablo İfadeleri (CTE'ler), bir sorgunun sonuçlarını geçici olarak saklar ve başka bir sorgu tarafından kullanılır

$$

  • CTE'ler sorgunun başında tanımlanır
  • WITH <cte-name> AS ( <query> )
  • Alt sorgulara benzer
-- CTE adını yazın, ardından
-- parantez içinde sorguyu ekleyin
WITH <cte-name> AS (
    <query>
)


SELECT ... FROM <cte-name> ... ;
Snowflake'te Veri İşleme

Risk altındaki öğrenciler için raporlama

WITH at_risk AS (
    SELECT
        student_id
        course_name,
        teacher_name,
        grade
    FROM student_courses
    WHERE grade < 70 AND is_required
)

SELECT students.student_name, at_risk.* FROM at_risk JOIN students ON at_risk.student_id = students.id;

$$

  • Geçici sonuçlar at_risk içinde saklanır
  • Kayıtların bir alt kümesini seçin
  • Rapor üretmek için at_risk sorgulanır

$$

$$

$$

Snowflake'te Veri İşleme

Risk altındaki öğrenciler için raporlama

Alt küme sonuçları ve nihai raporu gösteren bir CTE çıktısı

Snowflake'te Veri İşleme

Alt sorgular ve CTE'lerin karşılaştırılması

SELECT
    month_num,
    AVG(differential) AS avg_differential
    MIN(differential) AS most_differential
FROM (

    SELECT
        month_num,
        windchill - temperature AS differential
    FROM weather
    WHERE 
        season = 'Winter' AND
        temperature < 32

)
GROUP BY month_num;
WITH daily_temperature_differential AS (
    SELECT
        month_num,
        windchill - temperature AS differential
    FROM weather
    WHERE 
        season = 'Winter' AND 
        temperature < 32
)

SELECT
    month_num,
    AVG(differential) AS avg_differential
    MIN(differential) AS most_differential
FROM daily_temperature_differential
GROUP BY month_num;
Snowflake'te Veri İşleme

Sıcaklık farkını bulma

WITH daily_temperature_differential AS (
    SELECT
        month_num,
        windchill - temperature AS differential
    FROM weather
    WHERE 
        season = 'Winter' AND 
        temperature < 32
)

SELECT month_num, AVG(differential) AS avg_differential MIN(differential) AS most_differential FROM daily_temperature_differential GROUP BY month_num;
          | month_num | differential |
          | --------- | ------------ |
          |     12    |      -12     |
          |     1     |      -3      |
          |     1     |       0      |
          |     2     |      -7      |

İlerleme, alt sorgulardan daha doğaldır.

| month_num | avg_differential | most_differential |
| --------- | ---------------- | ----------------- |
|     12    |       -5.77      |        -14        |
|     1     |       -1.91      |        -8         |
|     2     |       -8.13      |        -22        |
Snowflake'te Veri İşleme

Hadi pratik yapalım!

Snowflake'te Veri İşleme

Preparing Video For Download...