MySQL: Выбор подстроки по номеру, ограниченную разделителями

Практика



Для того, чтобы выбрать подстроку, зная ее порядковый номер по отношению к разделительным символам, нам нужно написать запрос из двух вложенных функций:

SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('AAA:BBB:CCC:DDD', ':', 4),':','-1') FROM mytable;

Здесь переменной величиной является цифра 4 как индекс строки (считается от 1, не от нуля!), сама строка (вместо нее можно, конечно, пользовать вывод другой функции или имя столбца) и разделитель (в нашем случае это двоеточие - ":")

Например, выше данный запрос выведет:

DDD

А если цифры 4 поменять на, скажем, 3:

CCC

Заметим, что -1 в первой функции НЕ МЕНЯЕТСЯ! Т.е. он таким и остается.


ЗЫ. Минус метода в том, что если мы выбираем подстроку под номером, который не существует, то MySQL все равно вернет последнюю найденную строку (не пустую строку и не NULL). Пример: выбираем подстроку номер 5 из строки "first:second:third" с разделитилями ":". Но пятой подстроки не существует - последняя - третья. MySQL нам все равно вернет "third".
создано: 2017-05-09
обновлено: 2026-03-09
389



Помог ли вам этот ответ?
Нажмите оценку и напишите коротко почему. Так мы сможем сделать следующие ответы точнее и полезнее.
Насколько вы довольны ответом?
Ваш отзыв напрямую влияет на качество следующих подсказок и ответов.


Поделиться:
Пожаловаться

Найди готовое или заработай

С нашими удобными сервисами без комиссии*

Как это работает? | Узнать цену?

Найти исполнителя
$0 / весь год.
  • У вас есть задание, но нет времени его делать
  • Вы хотите найти профессионала для выполнения задания
  • Возможно применение функции гаранта на сделку
  • Приоритетная поддержка
  • идеально подходит для студентов, у которых нет времени для решения заданий
Готовое решение
$0 / весь год.
  • Вы можете продать (как исполнитель) или купить (как заказчик) готовое решение
  • Вам предоставят готовое решение
  • Будет предоставлено в минимальные сроки т.к. задание уже готовое
  • Вы получите базовую гарантию 8 дней
  • Вы можете заработать на материалах
  • подходит как для студентов так и для преподавателей
Я исполнитель
$0 / весь год.
  • Вы профессионал своего дела
  • У вас есть опыт и желание зарабатывать
  • Вы хотите помочь в решении задач или написании работ
  • Возможно применение функции гаранта на сделку
  • подходит для опытных студентов так и для преподавателей

Комментарии

Оставить комментарий

Если у вас есть какое-либо предложение, идея, благодарность или комментарий, не стесняйтесь писать. Мы очень ценим отзывы и рады услышать ваше мнение.
To reply

Лекции и учебник по "Базы данных - MySql (Maria DB)"

Термины: Базы данных - MySql (Maria DB)