Memutar Data

Tipe Data dan Fungsi di Snowflake

Jake Roach

Field Data Engineer

Tabel teragregasi

                   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
Tipe Data dan Fungsi di Snowflake

Tabel “pivot”




         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



Tipe Data dan Fungsi di Snowflake

Membuat tabel pivot

SELECT
    *
FROM SCHEMA.TABLE

PIVOT(
-- Fungsi agregasi SUM(<1>)
-- Tentukan baris yang diputar jadi kolom FOR <2> IN (ANY ORDER BY <2>) -- Tidak perlu GROUP BY! );

PIVOT memberi cara lain untuk menampilkan data teragregasi dengan “memutar” nilai menjadi kolom

  • SELECT * bisa pakai EXCLUDE
  • PIVOT diletakkan setelah FROM ...
  • Nilai ANY di <2>

$$

<1>: field untuk diagregasi

<2>: nilai baris yang jadi kolom

Tipe Data dan Fungsi di Snowflake

CTE dan data pivot

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

SELECT * -- Bisa juga pakai EXCLUDE FROM exam_grades PIVOT( AVG(exam_score) FOR exam_type IN (ANY ORDER BY exam_type) );

Pertama, buat CTE sebelum memakai PIVOT!

$$

             SELECT * FROM <cte>

$$

$$

$$

exam_score: field untuk diagregasi

exam_type: nilai baris yang jadi kolom

Tipe Data dan Fungsi di Snowflake

Membandingkan nilai ujian per jenis

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

SELECT * EXCLUDE course_abbreviation -- Hapus course_abbrevation dari hasil FROM exam_grades
PIVOT( AVG(exam_score) FOR exam_type IN (ANY ORDER BY exam_type) );
Tipe Data dan Fungsi di Snowflake

Membandingkan nilai ujian per jenis

                 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
Tipe Data dan Fungsi di Snowflake

Ayo berlatih!

Tipe Data dan Fungsi di Snowflake

Preparing Video For Download...