В таблице 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 в Telegram

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