Вам бонус- начислено 1 монета за дневную активность. Сейчас у вас 1 монета

MySQL: поиск вхождения в массиве, который является строкой с разделителями

Практика



Представим себе, что у нас есть строка с набором некоторых индексов или еще каких-то значений, разделенных разделителем. Такое может быть результатом php-фукнции implode или MySQL-фукнции GROUP_CONCAT, которые объединяют значения массива в строку через разделители. И нам надо с помощью MySQL найти в этом массиве (или не найти) некоторый элемент.

Для этого воспользуемся FIND_IN_SET. Эта функция ищет вхождение заданной строки в массив, который записан в другую строку через разделитель (запятую). К сожалению, разделитель поменять нельзя - только запятая.

Итак, приведем пример.

SELECT FIND_IN_SET('3', mytable.myset) FROM mytable

Этот запрос выведет индекс найденного значения '3' в каждой строке myset из таблицы mytable.

Давайте посмотрим исходную таблицу и результат запроса:

mytable
---
one   93,16,24
two   12,3,100
thr   3,9,12

result
---
0
2
1


Другой пример:

SELECT title FROM mytable WHERE FIND_IN_SET('3', mytable.myset)

Этот пример выведет все строки таблицы mytable, в значении myset которых имеется "3" (но не 33, не 63, и не 39).

Вот пример исходной таблицы и результата этого запроса:

mytable
---
title myset
one   93,16,24
two   12,3,100
thr   3,9,12

result
---
two
thr
создано: 2017-05-09
обновлено: 2024-11-10
1675



Рейтиг 9 of 10. count vote: 2
Вы довольны ?:


Поделиться:

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

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

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

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

Комментарии


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

Базы данных - MySql (Maria DB)

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