У пользователя first_name = ' Анна ' и last_name = ' Иванова ' (с лишними пробелами по краям). Что вернёт SELECT CONCAT(TRIM(first_name), ' ', TRIM(last_name))?
AРезультат будет
'Анна Иванова' — CONCAT склеит строки, а TRIM уберёт лишние пробелыBРезультат будет
'АннаИванова' — CONCAT склеивает строки без разделителя между нимиCРезультат будет
NULL, потому что CONCAT с пробелом внутри вызывает ошибку преобразованияDРезультат будет
' Анна Иванова ' — TRIM не влияет на пробелы внутри строковых значенийПравильный ответ.
TRIM убирает пробелы по краям строки, а CONCAT склеивает несколько строк в одну.Разбор
TRIM(' Анна ') вернёт 'Анна' — пробелы слева и справа удалены. Аналогично TRIM(' Иванова ') вернёт 'Иванова'. Затем CONCAT склеит три части: 'Анна', ' ' (пробел-разделитель) и 'Иванова' — итог 'Анна Иванова'. Это стандартный паттерн для формирования полного имени из отдельных полей с очисткой.
Проверь себя · 1/3разбор после ответа
В запросе используется выражение:
SELECT user_id, CASE WHEN age < 18 THEN 'подросток' WHEN age < 30 THEN 'молодой' WHEN age < 50 THEN 'средний' ELSE 'старший' END AS segment FROM users. Пользователю 25 лет — какое значение он получит и почему?Ещё вопросы по теме «Основы 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-запросов» →