Daha Fazla Sıralama Fonksiyonu

Snowflake'ta Pencere Fonksiyonları

Jake Roach

Field Data Engineer

RANK ve DENSE_RANK

SELECT
    workout_duration,

    RANK() OVER(
        ORDER BY workout_duration DESC
    ) AS r,

-- Boşluk olmadan! DENSE_RANK() OVER( ORDER BY workout_duration DESC ) AS dr
FROM FITNESS.workouts;
   workout_duration  |   r   |   dr
  ------------------ | ----- | -----
         78          |   1   |   1
         71          |   2   |   2
         71          |   2   |   2

    ***  68          |   4   |   3  ***

         67          |   5   |   4
         67          |   5   |   4
         67          |   5   |   4
         63          |   8   |   5
         61          |   9   |   6
Snowflake'ta Pencere Fonksiyonları

NTH_VALUE

SELECT
    <field>,
    <another-field>,

NTH_VALUE(<1>, <n>) OVER( PARTITION BY <2> ORDER BY <3> ) AS <alias>
FROM <SCHEMA>.<table>;

NTH_VALUE, bir pencere içindeki "N'inci" kayıttan belirtilen değeri döndürür, FIRST/LAST_VALUE'a benzer

$$

<1>: Satırdan alınacak değer

<n>: Alınacak satır numarası

<2>: Opsiyonel bölünecek alan

<3>: Kayıtların sıralamasını belirler ORDER BY

Snowflake'ta Pencere Fonksiyonları

NTH_VALUE

SELECT
    gym_location,
    workout_duration,

-- Her spor salonu için ikinci en uzun antrenman süresini döndür NTH_VALUE(workout_duration, 2) OVER( PARTITION BY gym_location ORDER BY workout_duration DESC ) AS second_longest_workout
FROM FITNESS.workouts;
Snowflake'ta Pencere Fonksiyonları

NTH_VALUE

      gym_location   |  workout_duration  |  second_longest_workout 
     --------------- | ------------------ | ------------------------
        New York     |        71          |           68            
        New York     |        68          |           68
        New York     |        67          |           68

        Los Angeles  |        78          |           67
        Los Angeles  |        67          |           67
        Los Angeles  |        67          |           67
        Los Angeles  |        63          |           67

        Miami        |        71          |           61
        Miami        |        61          |           61   
Snowflake'ta Pencere Fonksiyonları

Hepsini Bir Araya Getirme

SELECT
    gym_location, workout_duration,

    NTH_VALUE(workout_duration, 2) OVER(
        PARTITION BY gym_location
        ORDER BY workout_duration DESC
    ) AS second_longest_workout,

    RANK() OVER(PARTITION BY gym_location ORDER BY workout_duration DESC) AS r,

    DENSE_RANK() OVER(PARTITION BY gym_location ORDER BY workout_duration DESC) AS dr,

FROM FITNESS.workouts;
Snowflake'ta Pencere Fonksiyonları

Hepsini Bir Araya Getirme

      gym_location   |  workout_duration  |  second_longest_workout  |  r  |   dr  
     --------------- | ------------------ | ------------------------ | --- | -----
        New York     |        71          |           68             |  1  |   1
        New York     |        68          |           68             |  2  |   2
        New York     |        67          |           68             |  3  |   3

        Los Angeles  |        78          |           67             |  1  |   1
        Los Angeles  |        67          |           67             |  2  |   2
        Los Angeles  |        67          |           67             |  2  |   2
        Los Angeles  |        63          |           67             |  4  |   3

        Miami        |        71          |           61             |  1  |   1
        Miami        |        61          |           61             |  2  |   2
Snowflake'ta Pencere Fonksiyonları

Haydi pratik yapalım!

Snowflake'ta Pencere Fonksiyonları

Preparing Video For Download...