Window Functions in Snowflake
Jake Roach
Field Data Engineer
LAG consente di confrontare un valore con uno in un record precedente
SELECT <fields>,LAG(<1>, <2>, <3>) OVER( PARTITION BY <4> ORDER BY <5> )...;
$$
$$
<1>: campo nel record precedente da recuperare
<2>: numero di record da "guardare indietro"
<3>: valore predefinito se il record non esiste, 0
<4>: campo per partizionare
<5>: campo per ordinare i record
$$

SELECT member_id AS m_id, workout_date AS wd, calories_burned AS cb, -- Recupera le calorie bruciate -- dall'ultimo allenamentoLAG(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
SELECT ... LAG(calories_burned, 1) OVER( PARTITION BY member_id ORDER BY workout_date ) AS past_cb, -- Trova la differenza nel numero di calorie bruciate ``` {sql} calories_burned - LAG(calories_burned, 1, calories_burned) OVER( PARTITION BY member_id ORDER BY workout_date ) AS more_cb,FROM fitness.workouts;
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
LEAD consente di confrontare un valore con uno in un record "futuro"
$$
<1>: campo nel record precedente da recuperare
<2>: numero di record da "guardare avanti"
<3>: valore predefinito se il record non esiste
<4>: campo per partizionare
<5>: campo per ordinare i record
SELECT <fields>,LEAD(<1>, <2>, <3>) OVER( PARTITION BY <4> ORDER BY <5> )...;
SELECT
member_id,
workout_date
calories_burned,
-- Dopo questo allenamento, trova la data del prossimo
LEAD(workout_date, 1) OVER(
PARTITION BY member_id
ORDER BY workout_date
) AS next_workout_date
FROM fitness.workouts;
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
Window Functions in Snowflake