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

NATURAL JOIN sütunları otomatik eşleştirir ve yinelenenleri kaldırırSözdizimi:
SELECT ...
FROM <table_one> [
{
| NATURAL [ { LEFT | RIGHT | FULL } [ OUTER ] ]
}
]
JOIN <table_two>
[ ... ]
NATURAL JOIN olmadanSELECT *
FROM pizzas AS p
JOIN pizza_type AS t
ON t.pizza_type_id = p.pizza_type_id

NATURAL JOIN ileSELECT *
FROM pizzas AS p
NATURAL JOIN pizza_type AS t

❌ İZİN VERİLMEZ ❌
select *
FROM pizzas AS p
NATURAL JOIN pizza_type AS t
ON t.pizza_type_id = p.pizza_type_id

$$
✅ İZİN VERİLİR ✅
WHERE ifadesiSELECT *
FROM pizzas AS p
NATURAL JOIN pizza_type AS t
WHERE pizza_type_id = 'bbq_ckn'
LATERAL JOIN: FROM içindeki bir alt sorgunun önceki tablo veya görünümlerden sütunlara başvurmasına izin verir.Sözdizimi:
SELECT ...
FROM <left_hand_expression> , --
LATERAL
(<right_hand_expression>)
left_hand_expression - Tablo, görünüm veya alt sorgu
right_hand_expression - Satır içi görünüm veya alt sorgu
SELECT p.pizza_id, lat.name, lat.category FROM pizzas AS p,LATERAL -- LATERAL anahtar sözcüğü ( SELECT * FROM pizza_type AS t-- Dış sorgu sütununa başvuru: p.pizza_type_id WHERE p.pizza_type_id = t.pizza_type_id) AS lat
SELECT
*
FROM orders AS o,
LATERAL (
-- total_spent hesaplayan alt sorgu
SELECT
SUM(p.price * od.quantity) AS total_spent
FROM order_details AS od
JOIN pizzas AS p
ON od.pizza_id = p.pizza_id
WHERE o.order_id = od.order_id
) AS t
ORDER BY o.order_id
Snowflake SQL'e Giriş