Introductie tot BigQuery
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(): De windowfunctie die het rijnummer retourneertOVER(): Definieert het windowframePARTITION BY customer_id: Groepeert data per klantORDER BY order_date: Sorteert data binnen elke partitieorder_sequence: Resultaat van de windowfunctieSELECT
product_id,
product_photos_qty,
-- Ordinale rang per rij
RANK() OVER(
ORDER BY product_photos_qty DESC
) as rank,
-- Percentielrang per rij
PERCENT_RANK() OVER(
ORDER BY product_photos_qty
) as percent
FROM ecommerce.ecomm_products
ORDER BY product_photos_qty DESC;

SELECT
product_id,
-- Geeft de waarde van de vorige rij
LAG(product_photos_qty) OVER(
ORDER BY product_photos_qty
) as lag,
product_photos_qty,
-- Geeft de waarde van de volgende rij
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
Rij-gebaseerde grenzen:
UNBOUNDED PRECEDING: Alle rijen ervoorUNBOUNDED FOLLOWING: Alle rijen erna[INT] ROWS PRECEDING: Aantal rijen ervoor[INT] ROWS FOLLOWING: Aantal rijen ernaSELECT
product_id,
product_photos_qty,
RANK() OVER(
ORDER BY product_photos_qty DESC
) as rank
FROM ecommerce.ecomm_products
-- Filteren met QUALIFY
QUALIFY rank < 4
ORDER BY product_photos_qty DESC;

HAVING kan niet, we aggregeren nietIntroductie tot BigQuery