Snowflake SQL'e Giriş
George Boorman
Senior Curriculum Manager, DataCamp

❌ Yanlış ❌
SELECT *
FROM order_details AS od
JOIN pizzas AS p -- ON koşulu yok, patlayan JOIN'lere yol açar

✅ Doğru ✅
SELECT *
FROM order_details AS od
JOIN pizzas AS p
ON od.pizza_id = p.pizza_id

UNION veya UNION ALL: Farkı bilinUNION yinelenenleri kaldırır, sorguyu yavaşlatırUNION ALL yinelenme yoksa daha hızlıdırSELECT
*
FROM SNOWFLAKE_SAMPLE_DATA.TPCH_SF100.ORDERS

SELECT *
FROM SNOWFLAKE_SAMPLE_DATA.TPCH_SF100.ORDERS
LIMIT 10

SELECT * kullanımı ⌛SELECT
*
FROM SNOWFLAKE_SAMPLE_DATA.TPCH_SF100.ORDERS

SELECT * kaçının ⚡SELECT o_orderdate,
o_orderstatus
FROM SNOWFLAKE_SAMPLE_DATA.TPCH_SF100.ORDERS

WHERE koşulunu başta kullanın JOIN öncesi filtre uygulayınJOIN daha az satır işlerSELECT orders.order_id,
orders.order_date,
pizza_type.name,
pizzas.pizza_size
FROM orders
JOIN order_details
ON orders.order_id = order_details.order_id
JOIN pizzas
ON order_details.pizza_id = pizzas.pizza_id
JOIN pizza_type
ON pizzas.pizza_type_id = pizza_type.pizza_type_id
WHERE orders.order_date = '2015-01-01'; -- JOIN'den sonra filtreleme
WITH filtered_orders AS (
SELECT *
FROM orders
WHERE order_date = '2015-01-01' -- JOIN'den önce CTE'de filtreleme
)
SELECT filtered_orders.order_id,
filtered_orders.order_date,
pizza_type.name,
pizzas.pizza_size
FROM filtered_orders -- CTE ile JOIN
JOIN order_details
ON filtered_orders.order_id = order_details.order_id
JOIN pizzas
ON order_details.pizza_id = pizzas.pizza_id
JOIN pizza_type
ON pizzas.pizza_type_id = pizza_type.pizza_type_id;
snowflake.account_usage.query_historySELECT query_text, start_time, end_time, execution_time
FROM
snowflake.account_usage.query_history
WHERE query_text ILIKE '%order_details%'

ILIKE: Büyük/küçük harf duyarsız eşleştirmeSELECT query_text,
start_time,
end_time,
execution_time
FROM
snowflake.account_usage.query_history
WHERE
execution_time > 1000

Snowflake SQL'e Giriş