Verileri Pivotlama

Snowflake'te Veri Türleri ve Fonksiyonlar

Jake Roach

Field Data Engineer

Toplanmış tablo

                   course_name  |  exam_type  |  avg_exam_score
                  ------------- | ----------- | ----------------
                    Calculus I  |  Exam 1     |       81.78
                    Calculus I  |  Exam 2     |       83.55
                    Calculus I  |  Final      |       80.93

                    Finance     |  Exam 1     |       89.47
                    Finance     |  Exam 2     |       90.39
                    Finance     |  Final      |       89.69

                    Marketing   |  Exam 1     |       94.11
                    Marketing   |  Exam 2     |       93.29
                    Marketing   |  Final      |       93.81
Snowflake'te Veri Türleri ve Fonksiyonlar

"Pivot" edilmiş tablo




         course_name  |    "Exam 1"   |    "Exam 2"   |  "Final"
        ------------- | ------------- | ------------- | ---------
          Calculus I  |     81.78     |     83.55     |   80.93
          Finance     |     89.47     |     90.39     |   89.69
          Marketing   |     94.11     |     93.29     |   93.81



Snowflake'te Veri Türleri ve Fonksiyonlar

Pivotlanmış tablo oluşturma

SELECT
    *
FROM SCHEMA.TABLE

PIVOT(
-- Toplama fonksiyonu SUM(<1>)
-- Satırları sütuna çevirin FOR <2> IN (ANY ORDER BY <2>) -- GROUP BY gerekmez! );

PIVOT, değerleri sütunlara "çevirerek" toplanmış veriyi farklı bir biçimde verir

  • SELECT * ile EXCLUDE kullanılabilir
  • PIVOT, FROM ... ifadesinden sonra gelir
  • <2> içindeki değerler ANY

$$

<1>: toplanacak alan

<2>: sütuna çevrilecek satır değerleri

Snowflake'te Veri Türleri ve Fonksiyonlar

CTE ve pivotlanmış veriler

WITH exam_grades AS (
    SELECT
        ..., exam_score, exam_type
    FROM SCHEMA.TABLE
    WHERE ...
)

SELECT * -- EXCLUDE de kullanılabilir FROM exam_grades PIVOT( AVG(exam_score) FOR exam_type IN (ANY ORDER BY exam_type) );

Önce, PIVOT kullanmadan bir CTE tanımlayın!

$$

             SELECT * FROM <cte>

$$

$$

$$

exam_score: toplanacak alan

exam_type: sütuna çevrilecek satır değerleri

Snowflake'te Veri Türleri ve Fonksiyonlar

Sınav notlarını türe göre karşılaştırma

WITH exam_grades AS (
    SELECT 
        course_name, course_abbreviation, exam_score, exam_type
    FROM STUDENTS.grades
    WHERE course_level = '101'
)

SELECT * EXCLUDE course_abbreviation -- Sonuç kümesinden course_abbrevation kaldırılır FROM exam_grades
PIVOT( AVG(exam_score) FOR exam_type IN (ANY ORDER BY exam_type) );
Snowflake'te Veri Türleri ve Fonksiyonlar

Sınav notlarını türe göre karşılaştırma

                 course_name  |   exam_type   |  avg_exam_score
                ------------- | ------------- | ----------------
                  Calculus I  |   Exam 1      |       81.78
                  Calculus I  |   Exam 2      |       83.55
                  Calculus I  |   Final       |       80.93

                  Finance     |   Midterm 1   |       89.47
                                     ...
                 course_name  |    "Exam 1 "  |    "Exam 2"   |  "Final"
                ------------- | ------------- | ------------- | ---------
                  Calculus I  |     81.78     |     83.55     |   80.93
                  Finance     |     89.47     |     90.39     |   89.69
                  Marketing   |     94.11     |     93.29     |   93.81
Snowflake'te Veri Türleri ve Fonksiyonlar

Hadi pratik yapalım!

Snowflake'te Veri Türleri ve Fonksiyonlar

Preparing Video For Download...