Snowflake SQL'e Giriş
George Boorman
Senior Curriculum Manager, DataCamp
FROM, WHERE, HAVING veya SELECT ifadelerinde kullanılırSELECT column1
FROM table1
WHERE column1 = (SELECT column2 FROM table2 WHERE condition)
-- Ana sorgu, alt sorguda bulunan en yüksek fiyata sahip pizzaları döndürür
SELECT pizza_id
FROM pizzas
-- En yüksek pizza fiyatını belirleyen ilişkisiz alt sorgu
WHERE price = (
SELECT MAX(price)
FROM pizzas
)
SELECT pt.name,
pz.price,
pt.category
FROM pizzas AS pz
JOIN pizza_type AS pt
ON pz.pizza_type_id = pt.pizza_type_id
WHERE pz.price = (
-- Her pizza kategorisi için azami fiyatı belirler
SELECT MAX(p2.price) -- Azami fiyat
FROM pizzas AS p2
WHERE -- İlişkili: dış sorgu sütununu kullanır
p2.pizza_type_id = pz.pizza_type_id
)
Genel sözdizimi:
-- WITH anahtar sözcüğü
WITH cte1 AS ( -- CTE adı
SELECT col_1, col_2
FROM table1
)
...
SELECT ...
FROM cte1 -- CTE'yi sorgula
;
WITH max_price AS ( -- max_price adlı CTE SELECT pizza_type_id, MAX(price) AS max_price FROM pizzas GROUP BY pizza_type_id )-- Ana sorgu SELECT pt.name, pz.price, pt.category FROM pizzas AS pz JOIN pizza_type AS pt ON pz.pizza_type_id = pt.pizza_type_id JOIN max_price AS mp -- max_price CTE'si ile join ON pt.pizza_type_id = mp.pizza_type_id WHERE pz.price < mp.max_price -- Fiyatı max_price CTE sütunuyla karşılaştır
-- Virgülle ayrılmış birden çok CTE tanımlayın WITH cte1 AS ( SELECT ... FROM ... ),cte2 AS ( SELECT ... FROM ... )-- Her iki CTE'yi birleştiren ana sorgu SELECT ... FROM cte1 JOIN cte2 ON ... WHERE ...
Snowflake SQL'e Giriş