В отчёте по городам вы делаете агрегацию по city, но видите две строки: Moscow и Moscow (с пробелом в конце). Как исправить это прямо в запросе?
AИспользовать
TRIM(city) и группировать по нему: SELECT TRIM(city) ... GROUP BY TRIM(city).BПривести к числу:
CAST(city AS int).CДобавить
LIMIT 1, чтобы осталась одна строка.DСравнить через
LIKE: city LIKE 'Moscow'.Правильный ответ. Лишние пробелы часто убирают
TRIM, особенно перед GROUP BY и JOIN.Разбор
Пробелы в начале/конце строки — частый «мусор» в данных. При GROUP BY такие значения считаются разными, поэтому появляются дубликаты групп. TRIM нормализует строку и делает агрегацию корректной без ручной чистки таблицы.
Проверь себя · 1/3разбор после ответа
В таблице
customers поле lifetime_value_text хранится как текст. Вы делаете топ клиентов по выручке, но сортировка выглядит неверно (например, 100 идёт раньше 20). Как исправить ORDER BY?Ещё вопросы по теме «Строки и приведение типов»
- У вас есть таблицы `users(email)` и `marketing_signups(email)`. В одной системе email сохраняется как `Ivan@Example.com`, в другой — `ivan@example.com`. Какой подход в `JOIN` чаще всего решает проблему без изменения данных в таблицах?
- В таблице `products` категория хранится как `Books`, `books`, `BOOKS`. Вы хотите отфильтровать все варианты категории «books» в одном запросе. Какое условие в `WHERE` наиболее надежно?
- Поле `price_text` хранит цены как текст, например `2`, `10`, `100`. Аналитик написал фильтр `WHERE price_text > '10'` и получил странные результаты. Что нужно поменять, если сравнение должно быть числовым?
- В `amount_text` суммы записаны как текст, но иногда встречается пустая строка `''`. Запрос `SUM(CAST(amount_text AS int))` падает. Какое выражение чаще всего решает проблему, превращая пустые строки в `NULL` перед кастом?
- В таблице `customers` поле `lifetime_value_text` хранится как текст. Вы делаете топ клиентов по выручке, но сортировка выглядит неверно (например, `100` идёт раньше `20`). Как исправить `ORDER BY`?
- Все вопросы по «Строки и приведение типов» →