Sıralama pencere fonksiyonları

Snowflake'ta Pencere Fonksiyonları

Jake Roach

Field Data Engineer

RANK()

SELECT
    user_id,
    event_name,
    distance_traveled,

    -- En yakın katılımcıları bulun
    RANK() OVER(
        ORDER BY km_traveled
    ) AS closest_concert_goer

FROM CONCERTS.attendance;

RANK(), kayıtlara bir alan temelinde "sıralama" atamak için kullanılır

$$

  • ROW_NUMBER() ile benzer
  • Eşitlikleri ele alır
  • ORDER BY ekleyin
Snowflake'ta Pencere Fonksiyonları

RANK()


  user_id  |    event_name   | km_traveled | closest_attendees 
 --------- | --------------- | ----------- | ----------------- 
  user_81  |  Lunar Drift    |     0.5     |         1         
  user_02  |  Lunar Drift    |     1.1     |         2         
  user_33  |  Crimson Arc    |     8.6     |         3         
  user_33  |  Neon Prophet   |     8.6     |         3         
  user_15  |  VibeStorm      |     17      |         5         
  user_94  |  The Dusk Owls  |     41      |         6         
  user_47  |  Lunar Drift    |     61      |         7         
  user_56  |  Crimson Arc    |     116     |         8         

Snowflake'ta Pencere Fonksiyonları

DESC ile RANK()

SELECT
    user_id,
    event_name,
    km_traveled,

    RANK() OVER(
        ORDER BY km_traveled DESC  -- ORDER BY'a DESC ekleyin
    ) AS furthest_concert_goer

FROM CONCERTS.attendance;
Snowflake'ta Pencere Fonksiyonları

DESC ile RANK()


  user_id  |    event_name   | km_traveled | closest_attendees -> furthest_attendees
 --------- | --------------- | ----------- | ----------------- -> ------------------
  user_81  |  Lunar Drift    |     0.5     |         1         ->          8        
  user_02  |  Lunar Drift    |     1.1     |         2         ->          7        
  user_33  |  Crimson Arc    |     8.6     |         3         ->          6        
  user_33  |  Neon Prophet   |     8.6     |         3         ->          6        
  user_15  |  VibeStorm      |     17      |         5         ->          4        
  user_94  |  The Dusk Owls  |     41      |         6         ->          3        
  user_47  |  Lunar Drift    |     61      |         7         ->          2        
  user_56  |  Crimson Arc    |     116     |         8         ->          1        

Snowflake'ta Pencere Fonksiyonları

FIRST_VALUE ve LAST_VALUE

FIRST_VALUE ve LAST_VALUE, sırasıyla bir pencerenin ilk ve son sıralı değerini bulur

$$

  • Bir sütundaki kayıtları, o sütunun ilk/son değeriyle karşılaştırır
  • Alan adını alır
  • Bir alan ile ORDER BY, bunlar eşleşmek zorunda değil
SELECT
    <other-fields>,

    -- FIRST_VALUE ve LAST_VALUE
    -- her ikisi de bir alan alır

    [FIRST/LAST]_VALUE(<field>) OVER(
        ORDER BY <field>
    ) AS <alias>

FROM SCHEMA.table
...;
Snowflake'ta Pencere Fonksiyonları

İyi ve Kötü

SELECT
    user_id, event_name, satisfaction_score,

FIRST_VALUE(satisfaction_score) OVER( ORDER BY satisfaction_score DESC ) AS most_satisfied,
LAST_VALUE(satisfaction_score) OVER( ORDER BY satisfaction_score DESC ) AS least_satisfied
FROM CONCERTS.attendance;
Snowflake'ta Pencere Fonksiyonları

İyi ve Kötü


 user_id |  event_name  | satisfaction_score | most_satisfied | least_satisfied 
 ------- | ------------ | ------------------ | -------------- | --------------- 
 user_26 | Pulse Theory |         71         |       98       |        4        
 user_71 | Echo Valley  |          9         |       98       |        4        
 user_26 | Echo Valley  |         82         |       98       |        4        
 user_57 | Nova Sway    |          4         |       98       |        4        
 user_39 | Nova Sway    |         22         |       98       |        4        
 user_38 | Bass Ritual  |         76         |       98       |        4        
 user_92 | Pulse Theory |         98         |       98       |        4        
 user_44 | Nova Sway    |         62         |       98       |        4        

Snowflake'ta Pencere Fonksiyonları

Haydi pratik yapalım!

Snowflake'ta Pencere Fonksiyonları

Preparing Video For Download...