Analitik fonksiyonlar

SQL Server'da Verileri İşlemek için Fonksiyonlar

Ana Voicu

Data Engineer

FIRST_VALUE()

FIRST_VALUE(numeric_expression) 
    OVER ([PARTITION BY column] ORDER BY column ROW_or_RANGE frame)
  • Sıralı bir kümedeki ilk değeri döndürür.

OVER yan tümcesi bileşenleri

Bileşen Durum Açıklama
PARTITION by column isteğe bağlı sonuç kümesini bölümlere ayırır
ORDER BY column zorunlu sonuç kümesini sıralar
ROW_or_RANGE frame isteğe bağlı bölüm sınırlarını belirler
SQL Server'da Verileri İşlemek için Fonksiyonlar

LAST_VALUE()

LAST_VALUE(numeric_expression) 
    OVER ([PARTITION BY column] ORDER BY column ROW_or_RANGE frame)
  • Sıralı bir kümedeki son değeri döndürür.
SQL Server'da Verileri İşlemek için Fonksiyonlar

Bölüm sınırları

RANGE BETWEEN start_boundary AND end_boundary
ROWS BETWEEN start_boundary AND end_boundary
Sınır Açıklama
UNBOUNDED PRECEDING bölümdeki ilk satır
UNBOUNDED FOLLOWING bölümdeki son satır
CURRENT ROW geçerli satır
PRECEDING önceki satır
FOLLOWING sonraki satır
SQL Server'da Verileri İşlemek için Fonksiyonlar

FIRST_VALUE() ve LAST_VALUE() örneği

SELECT
    first_name + ' ' + last_name AS name,
    gender,
    total_votes AS votes,    
    FIRST_VALUE(total_votes) 
    OVER (PARTITION BY gender ORDER BY total_votes) AS min_votes,
    LAST_VALUE(total_votes) 
        OVER (PARTITION BY gender ORDER BY total_votes 
                ROWS BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING) AS max_votes
FROM voters;
| name            | gender | votes | min_votes | max_votes |
|-----------------|--------|-------|-----------|-----------|
| Michele Suarez  | F      | 20    | 20        | 189       |
| ...             | ...    | ...   | 20        | 189       |
| Marcus Jenkins  | M      | 16    | 16        | 182       |
| Micheal Vazquez | M      | 18    | 16        | 182       |
SQL Server'da Verileri İşlemek için Fonksiyonlar

LAG() ve LEAD()

LAG(numeric_expression) OVER ([PARTITION BY column] ORDER BY column)

  • Aynı sonuç kümesindeki önceki satırdan veri getirir.

LEAD(numeric_expression) OVER ([PARTITION BY column] ORDER BY column)

  • Aynı sonuç kümesindeki sonraki satırdan veri getirir.
SQL Server'da Verileri İşlemek için Fonksiyonlar

LAG() ve LEAD() örneği

SELECT 
    broad_bean_origin AS bean_origin,
    rating,
    cocoa_percent,
    LAG(cocoa_percent) OVER(ORDER BY rating ) AS percent_lower_rating,
    LEAD(cocoa_percent) OVER(ORDER BY rating ) AS percent_higher_rating
FROM ratings
WHERE company = 'Felchlin'
ORDER BY rating ASC;
| bean_origin        | rating | cocoa_percent | percent_lower_rating | percent_higher_rating |
|--------------------|--------|---------------|----------------------|-----------------------|
| Grenada            | 3      | 0.58          | NULL                 | 0.62                  |
| Dominican Republic | 3.75   | 0.62          | 0.58                 | 0.64                  |
| Madagascar         | 3.75   | 0.64          | 0.74                 | 0.65                  |
| Venezuela          | 4      | 0.65          | 0.74                 | NULL                  |
SQL Server'da Verileri İşlemek için Fonksiyonlar

Haydi pratik yapalım!

SQL Server'da Verileri İşlemek için Fonksiyonlar

Preparing Video For Download...