CTE (Common Table Expression)
Именованный подзапрос, объявленный через WITH. Делает сложные запросы читаемыми.
WITH cte_name AS ( SELECT ... ) SELECT ... FROM cte_name;
Объяснение
Пример
WITH monthly_revenue AS (
SELECT
DATE_TRUNC('month', created_at) AS month,
SUM(total) AS revenue
FROM orders
WHERE status = 'paid'
GROUP BY 1
),
growth AS (
SELECT month, revenue,
LAG(revenue) OVER (ORDER BY month) AS prev_revenue
FROM monthly_revenue
)
SELECT month, revenue,
ROUND((revenue - prev_revenue) * 100.0 / prev_revenue, 1) AS growth_pct
FROM growth
ORDER BY month;Связанные термины
Анекдоты по теме
— Что такое рекурсивный CTE? — Это когда CTE ссылается на самого себя. — Зачем? — Чтобы обходить деревья и графы. Иерархия сотрудников, категории товаров. — Это не приведёт к бесконечному циклу? — Приведёт, если забыть условие остановки.
— Доктор, у меня шизофрения. — Это лечится. Расскажите подробно. — WITH моей_личности AS (SELECT боль, радость, тревогу, ROW_NUMBER() OVER (PARTITION BY день_недели ORDER BY кофеин DESC) FROM психика)... Ой, кажется, я только что создал три новых партиции самосознания.
— Зачем нужен CTE? — Чтобы сложный запрос стал читаемым. — А чем он лучше подзапроса? — Подзапрос — это как объяснить рецепт блюда прямо внутри инструкции по приготовлению. CTE — как написать рецепт отдельно и сослаться на него.