Запрос `SELECT LAST_VALUE(amount) OVER (PARTITION BY user_id ORDER BY order_date) FROM orders` возвращает странный результат — вместо последней суммы по пользователю приходит текущая. Почему?
SQLhardsenior
Варианты ответа
У LAST_VALUE по умолчанию frame = ROWS/RANGE BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW, надо явно задать UNBOUNDED FOLLOWING
LAST_VALUE всегда возвращает текущую строку, это известный баг — использовать MAX() OVER()
Нужно убрать ORDER BY — с ORDER BY LAST_VALUE работает как FIRST_VALUE
PARTITION BY несовместим с LAST_VALUE — нужно убрать партицию
Разбор ответа
Подробный разбор с объяснением «почему правильный ответ верный» и почему остальные неверны — после регистрации.
2475 вопросов с разбором, quiz-режим с проверкой, AI-собес и подготовка к интервью аналитика.