Conditional Change Event (CONDITIONAL_CHANGE_EVENT
) is a versatile Snowflake function that returns a window event number for each row when the value of the expression is different from the value in the previous row.
This can be a very powerful function to use when analyzing events data or time-series data. For e.g. if you need to retrieve the first update_date
by Support Engineer per Case Status change in the following data:
data:image/s3,"s3://crabby-images/8e76e/8e76e2b01ac5717e10ae8e43709bf160548ea6f3" alt="Screen Shot 2024-12-04 at 9 09 14 PM" |
We need the first status_date by Support Engineer per Case Status change |
with support_cases as (
select *
, conditional_change_event (status || support_engineer)
over (partition by case_number order by update_date asc) as change_rank_number
from support_case
);
data:image/s3,"s3://crabby-images/da9a9/da9a9896bd875c56b232d98f9d31c2d2cc9ce693" alt="Screen Shot 2024-12-05 at 6 42 19 PM" |
change_rank_number increases each time the Support Engineer + Status combination changes |
with support_cases as (
select *
, conditional_change_event (status || support_engineer)
over (partition by case_number order by update_date asc) as change_rank_number
from support_case
)
select * from support_cases
qualify row_number() over (partition by case_number, change_rank_number order by update_date) = 1;
data:image/s3,"s3://crabby-images/731bc/731bc12535c12d4bcbbcd89690339a2f292909f1" alt="Screen Shot 2024-12-05 at 7 23 50 PM" |
first status_date by Support Engineer per Case Status change |
See also