Fungsi jendela agregat

Fungsi Window di Snowflake

Jake Roach

Field Data Engineer

Fungsi jendela agregat

      m_id  |       wd     |   cb  |  num_workouts  |  total_cb  |  cb_vs_average 
     ------ | ------------ | ----- | -------------- | ---------- | ---------------
     m_192  |  2024-01-01  |  105  |        4       |     432    |      -3
     m_192  |  2024-01-03  |  156  |        4       |     432    |      48
     m_192  |  2024-01-04  |   69  |        4       |     432    |     -39
     m_192  |  2024-01-10  |  102  |        4       |     432    |      -6

     m_74   |  2024-02-10  |  374  |        3       |    1274    |     -50.67   
     m_74   |  2024-02-13  |  396  |        3       |    1274    |     -28.67
     m_74   |  2024-02-14  |  504  |        3       |    1274    |     -79.33

     m_233  |  2024-03-05  |  51   |        2       |     132    |     -15
     m_233  |  2024-03-12  |  81   |        2       |     132    |      15
Fungsi Window di Snowflake

Fungsi jendela agregat, AVG

SELECT
    <fields>,

-- Tidak perlu ORDER BY! AVG(<1>) OVER( PARTITION BY <2> ) AS <alias>
...

<1>: kolom untuk rata-rata

<2>: bidang untuk partisi data

  • Menghitung metrik ringkasan dan menampilkan hasil untuk setiap catatan dalam jendela

$$

  • Manfaatkan keluaran fungsi ini dengan operator seperti +, -, *, /
  • AVG, COUNT, SUM
  • Tidak perlu ORDER BY!
Fungsi Window di Snowflake

AVG

SELECT
    member_id AS m_id, 
    calories_burned AS cb,

-- Pertama, rata-rata kalori terbakar AVG(calories_burned) OVER( PARTITION BY member_id ) AS avg_cb,
-- Kemudian, selisih vs. rata-rata calories_burned - AVG(calories_burned) OVER( PARTITION BY member_id ) AS cb_vs_average
FROM fitness.workouts;

    m_id  |   cb  |   avg_cb  |  cb_vs_average
   ------ | ----- | --------- | ---------------
   m_192  |  105  |    108    |       -3
   m_192  |  156  |    108    |       48
   m_192  |   69  |    108    |      -39
   m_192  |  102  |    108    |       -6

   m_74   |  374  |   424.67  |     -50.67   
   m_74   |  396  |   424.67  |     -28.67
   m_74   |  504  |   424.67  |      79.33

   m_233  |   51  |     66    |      -15
   m_233  |   81  |     66    |       15

Fungsi Window di Snowflake

COUNT

SELECT
    member_id AS m_id, 
    workout_date AS wd,

    -- Dapat menggunakan '*' untuk COUNT
    COUNT(*) OVER(
        PARTITION BY member_id
    ) AS num_workouts

FROM fitness.workouts
ORDER BY member_id, workout_date;

Dapat menggunakan * untuk COUNT!

   m_id  |      wd      |  num_workouts
  ------ | ------------ | --------------
  m_192  |  2024-01-01  |        4     
  m_192  |  2024-01-03  |        4     
  m_192  |  2024-01-04  |        4     
  m_192  |  2024-01-10  |        4     

  m_74   |  2024-02-10  |        3     
  m_74   |  2024-02-13  |        3     
  m_74   |  2024-02-14  |        3     

  m_233  |  2024-03-05  |        2      
  m_233  |  2024-03-12  |        2     
Fungsi Window di Snowflake

SUM

SELECT
    member_id AS m_id, 
    calories_burned AS cb,

-- Total kalori terbakar untuk member id SUM(calories_burned) OVER( PARTITION BY member_id ) AS total_cb,
-- Temukan proporsi total calories_burned / SUM(calories_burned) OVER( PARTITION BY member_id ) AS total_cb
FROM fitness.workouts;

       m_id  |   cb  |  total_cb  |  prop_cb 
      ------ | ----- | ---------- | ---------
      m_192  |  105  |     432    |   0.2431
      m_192  |  156  |     432    |   0.3611
      m_192  |   69  |     432    |   0.1597
      m_192  |  102  |     432    |   0.2361

      m_74   |  374  |    1274    |   0.2935
      m_74   |  396  |    1274    |   0.3108
      m_74   |  504  |    1274    |   0.3956

      m_233  |  51   |     132    |   0.3864
      m_233  |  81   |     132    |   0.6136

Fungsi Window di Snowflake

Evaluasi latihan member

SELECT
    member_id AS m_id, workout_date AS wd, calories_burned AS cb,

COUNT(*) OVER( -- Temukan jumlah latihan PARTITION BY member_id ) AS num_workouts,
SUM(calories_burned) OVER( -- Total kalori terbakar untuk setiap member PARTITION BY member_id ) AS total_cb,
calories_burned - AVG(calories_burned) OVER( -- Bandingkan kalori terbakar dengan rata-rata PARTITION BY member_id ) AS cb_vs_average
FROM fitness.workouts;
Fungsi Window di Snowflake

Evaluasi latihan member

      m_id  |       wd     |   cb  |  num_workouts  |  total_cb  |  cb_vs_average 
     ------ | ------------ | ----- | -------------- | ---------- | ---------------
     m_192  |  2024-01-01  |  105  |        4       |     432    |      -3
     m_192  |  2024-01-03  |  156  |        4       |     432    |      48
     m_192  |  2024-01-04  |   69  |        4       |     432    |     -39
     m_192  |  2024-01-10  |  102  |        4       |     432    |      -6

     m_74   |  2024-02-10  |  374  |        3       |    1274    |     -50.67   
     m_74   |  2024-02-13  |  396  |        3       |    1274    |     -28.67
     m_74   |  2024-02-14  |  504  |        3       |    1274    |      79.33

     m_233  |  2024-03-05  |  51   |        2       |     132    |     -15
     m_233  |  2024-03-12  |  81   |        2       |     132    |      15
Fungsi Window di Snowflake

Ayo berlatih!

Fungsi Window di Snowflake

Preparing Video For Download...