Pengantar Pemodelan Data di Snowflake
Nuno Rocha
Director of Engineering






SELECT DISTINCT category
FROM allproducts;

SELECT TRIM(category)
FROM allproducts;

SELECT TRIM(f.value)
FROM allproducts,
LATERAL FLATTEN(INPUT => SPLIT(allproducts.category, ',')) f;

CREATE OR REPLACE TABLE categories (
category_id NUMBER(10,0) PRIMARY KEY,
category VARCHAR(255)
);
INSERT INTO: Perintah SQL untuk memasukkan baris baru ke tabel.INSERT INTO categories (category_id, category)
___;
INSERT INTO categories (category_id, category)
SELECT
___,
___
FROM allproducts;
INSERT INTO categories (category_id, category)
SELECT
___,
TRIM(f.value)
FROM allproducts,
LATERAL FLATTEN(INPUT => SPLIT(allproducts.category, ',')) f;
INSERT INTO categories (category_id, category)
SELECT
ROW_NUMBER() OVER (ORDER BY TRIM(f.value)),
TRIM(f.value)
FROM allproducts,
LATERAL FLATTEN(INPUT => SPLIT(allproducts.category, ',')) f;
INSERT INTO categories (category_id, category)
SELECT
ROW_NUMBER() OVER (ORDER BY TRIM(f.value)),
TRIM(f.value)
FROM allproducts,
LATERAL FLATTEN(INPUT => SPLIT(allproducts.category, ',')) f
GROUP BY TRIM(f.value);

INSERT INTO: Perintah SQL untuk menambahkan baris baruTRIM: Fungsi SQL untuk menghapus spasi di awal dan akhir nilaiLATERAL FLATTEN(INPUT => SPLIT()): Fungsi Snowflake untuk membagi nilai menjadi barisROW_NUMBER() OVER (ORDER BY): Fungsi SQL untuk menghasilkan nomor berurutanGROUP BY: Klausa SQL untuk mengelompokkan data dengan nilai yang sama-- Isi entitas dengan data dari hasil kueri
INSERT INTO table_name (column_name, other_columns)
SELECT
-- Hasilkan nilai unik menggunakan nomor baris
ROW_NUMBER() OVER (ORDER BY TRIM(alias.value)),
TRIM(alias.value)
FROM another_table,
-- Bagi nilai atribut teks berdasarkan pemisah
LATERAL FLATTEN(INPUT => SPLIT(another_table.column_name, 'delimiter_value'))alias
-- Agregasikan data untuk memastikan nilai unik
GROUP BY TRIM(alias.value);
Pengantar Pemodelan Data di Snowflake