Snowflake ile Veri Modellemesine Giriş
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: Bir tabloya yeni satırlar ekler.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: Bir tabloya yeni satırlar eklerTRIM: Değerlerin başındaki ve sonundaki boşlukları kaldırırLATERAL FLATTEN(INPUT => SPLIT()): Değerleri satırlara bölerROW_NUMBER() OVER (ORDER BY): Sıralı numara üretirGROUP BY: Aynı değerlere sahip verileri gruplayıp toplar-- Bir varlığı sorgu sonucu ile doldurun
INSERT INTO table_name (column_name, other_columns)
SELECT
-- Satır numarasıyla benzersiz değer üretin
ROW_NUMBER() OVER (ORDER BY TRIM(alias.value)),
TRIM(alias.value)
FROM another_table,
-- Bir metin özniteliğini ayıraca göre bölün
LATERAL FLATTEN(INPUT => SPLIT(another_table.column_name, 'delimiter_value'))alias
-- Değerlerin tekilliğini sağlamak için gruplayın
GROUP BY TRIM(alias.value);
Snowflake ile Veri Modellemesine Giriş