BigQuery'ye Giriş
Matthew Forrest
Field CTO


SELECT customer_id, order_date, order_total, ROW_NUMBER() OVER(PARTITION BY customer_idORDER BY order_date) AS order_sequence FROM orders;
ROW_NUMBER(): Satır numarasını döndüren window fonksiyonuOVER(): Pencere çerçevesini tanımlarPARTITION BY customer_id: Veriyi müşteri bazında bölerORDER BY order_date: Her bölüm içinde sıralarorder_sequence: Window işleminin sonucuSELECT
product_id,
product_photos_qty,
-- Her satır için sıralama değeri
RANK() OVER(
ORDER BY product_photos_qty DESC
) as rank,
-- Her satır için yüzdelik sırası
PERCENT_RANK() OVER(
ORDER BY product_photos_qty
) as percent
FROM ecommerce.ecomm_products
ORDER BY product_photos_qty DESC;

SELECT
product_id,
-- Önceki satırın değerini döndürür
LAG(product_photos_qty) OVER(
ORDER BY product_photos_qty
) as lag,
product_photos_qty,
-- Sonraki satırın değerini döndürür
LEAD(product_photos_qty) OVER(
ORDER BY product_photos_qty
) as lead
FROM ecommerce.ecomm_products
ORDER BY product_photos_qty DESC;

SELECT
order_id,
order_timestamp,
SUM(cost) OVER(
ORDER BY order_timestamp
ROWS BETWEEN 2 PRECEDING
AND CURRENT ROW) as rolling_avg
FROM sales_data
ORDER BY order_timestamp
Satır tabanlı sınır seçenekleri:
UNBOUNDED PRECEDING: Tüm önceki satırlarUNBOUNDED FOLLOWING: Tüm sonraki satırlar[INT] ROWS PRECEDING: Belirli sayıda önceki satır[INT] ROWS FOLLOWING: Belirli sayıda sonraki satırSELECT
product_id,
product_photos_qty,
RANK() OVER(
ORDER BY product_photos_qty DESC
) as rank
FROM ecommerce.ecomm_products
-- QUALIFY ile filtreleyin
QUALIFY rank < 4
ORDER BY product_photos_qty DESC;

HAVING kullanılamazBigQuery'ye Giriş