Pencere Çerçeveleri

Snowflake'ta Pencere Fonksiyonları

Jake Roach

Field Data Engineer

Pencere Çerçeveleri

Tüm kayıtları içeren bir pencere gösterimi.

Snowflake'ta Pencere Fonksiyonları

Pencere Çerçeveleri

Kayıtları bölmek için member_id alanını kullanan pencere gösterimi.

Snowflake'ta Pencere Fonksiyonları

Dinamik Pencere Çerçeveleri

"Kaydırmalı" pencere çerçevesi gösterimi.

Snowflake'ta Pencere Fonksiyonları

Sürekli Hesaplama Bulma

SELECT
    ...

    AVG(<1>) OVER(
        PARTITION BY ...
        ORDER BY <2>

        -- İlk ve mevcut satır arasında pencere

ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW
) ...

ROWS BETWEEN dinamik pencere çerçevesi oluşturur

  • UNBOUNDED PRECEEDING AND CURRENT ROW
  • İlk satırdan mevcut satıra kadar
  • "Sürekli" hesaplama, yuvarlanmıyor
  • CURRENT ROW AND UNBOUNDED FOLLOWING

$$

<1>: hesaplama yapılacak alan

<2>: sonuçları sıralar, pencere çerçevesi oluşturur

Snowflake'ta Pencere Fonksiyonları

Yakılan Kalorilerin Toplamı

SELECT
    member_id AS m_id, 
    calories_burned AS cb,

    -- Toplam kalori!
    SUM(calories_burned) OVER(
        PARTITION BY member_id
        ORDER BY workout_date

ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW
) AS running_total FROM fitness.workouts;

         m_id  |    cb   |  running_total
       ------- | ------- | --------------
        m_192  |   105   |      105 
        m_192  |   156   |      261 
        m_192  |    69   |      330 
        m_192  |   102   |      432  

        m_74   |   374   |      374  
        m_74   |   396   |      770  
        m_74   |   504   |     1274  

        m_233  |    51   |       51  
        m_233  |    81   |      132  

Snowflake'ta Pencere Fonksiyonları

MEVCUT SATIR VE SONRASINDAKİLER

SELECT
    member_id AS m_id, 
    calories_burned AS cb,

    SUM(calories_burned) OVER(
        PARTITION BY member_id
        ORDER BY workout_date

        -- Mevcut satır ve sonrasındaki pencere

ROWS BETWEEN CURRENT ROW AND UNBOUNDED FOLLOWING
) AS left_to_burn FROM fitness.workouts;

         m_id  |    cb   |  left_to_burn
       ------- | ------- | --------------
        m_192  |   105   |      432 
        m_192  |   156   |      327 
        m_192  |    69   |      171 
        m_192  |   102   |      102  

        m_74   |   374   |     1274  
        m_74   |   396   |      900 
        m_74   |   504   |      504  

        m_233  |    51   |      132  
        m_233  |    81   |       81  

Snowflake'ta Pencere Fonksiyonları

Kalori Yakma Eğilimleri

SELECT
    member_id,
    workout_date,
    calories_burned,

    AVG(calories_burned) OVER(   -- Yakılan kalorilerin ortalaması
        PARTITION BY member_id

        -- İlk antrenmandan mevcut antrenmana kadar pencere oluştur
        ORDER BY workout_date
        ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW

    ) AS avg_calories_burned

FROM FITNESS.workouts;
Snowflake'ta Pencere Fonksiyonları

Kalori Yakma Eğilimleri


            member_id  |  workout_date  |  calories_burned  |  average_calories_burned
           ----------- | -------------- | ----------------- | -------------------------
              m_192    |   2025-01-01   |        105        |          105.0
              m_192    |   2025-01-03   |        156        |          130.5
              m_192    |   2025-01-04   |         69        |          110.0
              m_192    |   2025-01-10   |        102        |          108.0

               m_74    |   2025-02-10   |        374        |          374.0
               m_74    |   2025-02-13   |        396        |          385.0
               m_74    |   2025-02-14   |        504        |          426.7

              m_233    |   2025-03-05   |         51        |           51.0
              m_233    |   2025-03-12   |         81        |           66.0

Snowflake'ta Pencere Fonksiyonları

Hadi pratik yapalım!

Snowflake'ta Pencere Fonksiyonları

Preparing Video For Download...