В таблице users email хранится в разном регистре: 'Anna@mail.ru', 'anna@MAIL.ru' и т.д. Как надёжнее всего найти все записи с конкретным адресом вне зависимости от регистра?
AПрименить
UPPER(email) в WHERE, чтобы привести к верхнему регистру перед сравнениемBИспользовать
TRIM(email) в WHERE, чтобы удалить пробелы и привести регистр к единомуCНаписать
WHERE email = 'anna@mail.ru' OR email = 'Anna@mail.ru' для обоих вариантовDПрименить
LOWER(email) в WHERE, чтобы привести к нижнему регистру перед сравнениемПравильный ответ. Функции
LOWER и UPPER приводят строку к единому регистру, что позволяет сравнивать без учёта регистра.Разбор
Чтобы сравнение не зависело от того, какие буквы заглавные, удобно привести обе стороны к одному регистру: WHERE LOWER(email) = LOWER('anna@mail.ru'). Перечисление всех возможных вариантов написания ненадёжно. Функция TRIM убирает пробелы, но не меняет регистр букв.
Проверь себя · 1/3разбор после ответа
У пользователя
first_name = ' Анна ' и last_name = ' Иванова ' (с лишними пробелами по краям). Что вернёт SELECT CONCAT(TRIM(first_name), ' ', TRIM(last_name))?Ещё вопросы по теме «Основы SQL-запросов»
- В таблице `users` нужно выбрать только активных пользователей из России или Казахстана. Какой `WHERE` соответствует требованию?
- Для отчёта по регистрациям вам нужны только `user_id` и `signup_at` из таблицы `users`. Какой запрос лучше соответствует задаче и не тянет лишние поля?
- Нужно получить 20 самых новых событий из таблицы `events` (по времени `event_time`) и показать их в выдаче сверху. Какой запрос верный?
- Вы строите выдачу «последние заказы» и используете `LIMIT 50`. Поле `created_at` не уникально (много заказов в одну секунду). Какой `ORDER BY` лучше, чтобы порядок был детерминированным?
- Что можно корректно утверждать про результат запроса `SELECT user_id FROM users LIMIT 10`, если в запросе нет `ORDER BY`?
- Все вопросы по «Основы SQL-запросов» →