LAG en LEAD

Vensterfuncties in Snowflake

Jake Roach

Field Data Engineer

LAG

LAG vergelijkt een waarde met een waarde in een vorig record

SELECT
    <fields>,

LAG(<1>, <2>, <3>) OVER( PARTITION BY <4> ORDER BY <5> )
...;

$$

$$

<1>: veld uit vorig record om op te halen

<2>: aantal records om terug te kijken

<3>: standaardwaarde als record ontbreekt, 0

<4>: veld om op te partitioneren

<5>: veld dat de sorteervolgorde bepaalt

Vensterfuncties in Snowflake

LAG

$$

Een voorbeelddataset gegenereerd met LAG

Vensterfuncties in Snowflake

LAG

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

    -- Haal het aantal verbrande calorieën op 
    -- van de vorige workout

LAG(calories_burned, 1) OVER( PARTITION BY member_id ORDER BY workout_date ) AS past_cb,
FROM fitness.workouts;
  m_id  |       wd     |   cb  |  past_cb 
 ------ | ------------ | ----- | ---------
 m_192  |  2024-01-01  |  105  |   null
 m_192  |  2024-01-03  |  156  |   105
 m_192  |  2024-01-04  |   69  |   156
 m_192  |  2024-01-10  |  102  |    69

 m_74   |  2024-02-10  |  374  |   null
 m_74   |  2024-02-13  |  396  |   374
 m_74   |  2024-02-14  |  504  |   396

 m_233  |  2024-03-05  |  51   |   null 
 m_233  |  2024-03-12  |  81   |    51
Vensterfuncties in Snowflake

LAG

SELECT
    ...
    LAG(calories_burned, 1) OVER(
        PARTITION BY member_id
        ORDER BY workout_date
    ) AS past_cb,

    -- Vind het verschil in aantal verbrande calorieën
``` {sql}
    calories_burned - LAG(calories_burned, 1, calories_burned) OVER(
        PARTITION BY member_id
        ORDER BY workout_date
    ) AS more_cb,

FROM fitness.workouts;
Vensterfuncties in Snowflake

LAG

                  m_id  |       wd     |   cb  |  past_cb  |  more_cb
                ------- | ------------ | ----- | --------- | ---------
                 m_192  |  2024-01-01  |  105  |    null   |      0
                 m_192  |  2024-01-03  |  156  |    105    |     51
                 m_192  |  2024-01-04  |   69  |    156    |    -87
                 m_192  |  2024-01-10  |  102  |     69    |     33

                 m_74   |  2024-02-10  |  374  |    null   |      0
                 m_74   |  2024-02-13  |  396  |    374    |     22
                 m_74   |  2024-02-14  |  504  |    396    |    108

                 m_233  |  2024-03-05  |  51   |    null   |      0
                 m_233  |  2024-03-12  |  81   |     51    |     30 
Vensterfuncties in Snowflake

LEAD

LEAD vergelijkt een waarde met een waarde in een "toekomstig" record

$$

<1>: veld uit volgend record om op te halen

<2>: aantal records om vooruit te kijken

<3>: standaardwaarde als record ontbreekt

<4>: veld om op te partitioneren

<5>: veld dat de sorteervolgorde bepaalt

SELECT
    <fields>,

LEAD(<1>, <2>, <3>) OVER( PARTITION BY <4> ORDER BY <5> )
...;
  • Vaak gebruikt voor voorspellende taken
Vensterfuncties in Snowflake

LEAD

SELECT
    member_id, 
    workout_date
    calories_burned,

    -- Vind na deze workout de datum van de volgende workout
    LEAD(workout_date, 1) OVER(
        PARTITION BY member_id
        ORDER BY workout_date
    ) AS next_workout_date

FROM fitness.workouts;
Vensterfuncties in Snowflake

LEAD

            m_id  |  workout_date  |  calories_bured  |  next_workout_date
          ------- | -------------- | ---------------- | -------------------
           m_192  |   2024-01-01   |        105       |     2024-01-03
           m_192  |   2024-01-03   |        156       |     2024-01-04
           m_192  |   2024-01-04   |         69       |     2024-01-10
           m_192  |   2024-01-10   |        102       |         null

           m_74   |   2024-02-10   |        374       |     2024-02-13
           m_74   |   2024-02-13   |        396       |     2024-02-14
           m_74   |   2024-02-14   |        504       |         null

           m_233  |   2024-03-05   |         51       |     2024-03-12 
           m_233  |   2024-03-12   |         81       |         null
Vensterfuncties in Snowflake

Laten we oefenen!

Vensterfuncties in Snowflake

Preparing Video For Download...