В таблице support_tickets поле resolved_at равно NULL, если тикет ещё не решён. Нужно вывести сначала нерешённые тикеты, а внутри них — по created_at по возрастанию (самые старые сверху). Какой ORDER BY лучше?

AORDER BY created_at ASC
BORDER BY resolved_at ASC NULLS FIRST, created_at ASC
CORDER BY resolved_at ASC NULLS LAST, created_at ASC
DORDER BY resolved_at DESC NULLS FIRST, created_at ASC
Правильный ответ. Сортируйте сначала по признаку «решён/не решён» через NULLS FIRST, а затем по времени создания.

Разбор

Чтобы нерешённые тикеты шли первыми, удобно сортировать по resolved_at так, чтобы NULL оказался сверху: resolved_at ASC NULLS FIRST. Затем добавляем вторичный критерий для очереди обработки: created_at ASC. Это даёт выдачу, где вверху будут нерешённые и среди них — самые старые.

Проверь себя · 1/3разбор после ответа
Аналитик пишет: SELECT clicks / NULLIF(views, 0) AS ctr FROM campaigns. Зачем здесь используется NULLIF(views, 0)?
Тренировать SQL в Telegram

Ещё вопросы по теме «Основы SQL-запросов»