Menerapkan logika kondisional di Snowflake

Manipulasi Data di Snowflake

Jake Roach

Field Data Engineer

Agregasi dengan pernyataan CASE

Query dengan pernyataan CASE tetap dapat memakai fungsi agregasi.

  • SUM()
  • AVG()
  • MIN()
  • MAX()
  • ...
  • MODE()

$$

Pastikan untuk menyertakan GROUP BY!

Kerangka pernyataan CASE yang mencakup agregasi dan pengelompokan

Manipulasi Data di Snowflake

Agregasi dengan pernyataan CASE

SELECT
    CASE
        WHEN month_num IN (12, 1, 2) THEN 'Winter'
        WHEN month_num IN (3, 4, 5) THEN 'Spring'
        WHEN month_num in (6, 7, 8) THEN 'Summer'
        ELSE 'Fall'
    END AS season,

AVG(temperature) AS average_temperature, -- Manipulate data with AVG()
year_num FROM weather GROUP BY season, year_num; -- Remember to group by non-aggregated fields
Manipulasi Data di Snowflake

Agregasi dengan pernyataan CASE

Hasil query yang mencari suhu rata-rata per musim dan tahun

Manipulasi Data di Snowflake

Mengagregasi field hasil CASE

SELECT
    season,
    AVG(
        CASE
            WHEN season = 'Winter' THEN temperature - 30
            WHEN season IN ('Spring', 'Fall') THEN temperature - 60
            WHEN season = 'Summer' THEN temperature - 75
        END
    ) AS relation_to_average_temperature
FROM weather
GROUP BY season;
Manipulasi Data di Snowflake

Mengagregasi field hasil CASE

Tabel yang menampilkan relasi suhu rata-rata per musim

Manipulasi Data di Snowflake

JOIN

SELECT
    ...

    -- Define a CASE statement
    CASE ...

FROM <left_table>

-- JOIN new records to existing table
LEFT JOIN <right_table> 
    ... 
;

Pernyataan CASE dapat dibuat menggunakan data yang di-join dari dua tabel berbeda.

  • Gunakan kolom dari lebih dari satu tabel dalam pernyataan CASE
  • LEFT, RIGHT, INNER, OUTER, dll.
  • Gabungkan dengan alat lain, termasuk fungsi agregasi

$$

$$

                                          Mari kita lihat!

Manipulasi Data di Snowflake

Menentukan status kredit kuliah

SELECT
    students.student_name,
    student_courses.course_name,

-- Evaluate both the student's grade number and grade for the course CASE WHEN students.grade_num = 12 AND student_courses.grade > 90 THEN 'College Credit Eligible' ELSE 'Too Early for College Credit' END AS college_credit_status
FROM student_courses LEFT JOIN students ON student_courses.student_id = students.student_id;
Manipulasi Data di Snowflake

Menentukan status kredit kuliah

Hasil query pada tabel students dan student_courses yang di-JOIN

Manipulasi Data di Snowflake

Ayo berlatih!

Manipulasi Data di Snowflake

Preparing Video For Download...