Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как написать sql между двумя полями типа set? 
:(
    Опции темы
taral
Дата 22.10.2014, 11:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 230
Регистрация: 17.1.2008

Репутация: нет
Всего: нет



Допустим у меня есть таблица
id value (type set)
1 a,b
2 r,d,g,h,a
3 g,s,e,a
4 k,l,p,o
И есть набор значений ['a','b','s','u','t']
Мне необходимо с таблицы выбрать те записи где есть хотя бы одно совпадение элемента с моего списка и с списка таблицы.
К примеру в строке 1 элемент 'a' присутствует и в моем списке.
И дополнительная задача. Нужно что бы в моем списке присутствовали все значения с списка строки таблицы. По этому примеру проходит только первая строка где элементы 'a' и 'b' есть в моем списке.
Спасибо за внимание. У меня пока нет идей как это лучше реализовать.
PM MAIL   Вверх
Romikgy
Дата 22.10.2014, 12:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Любитель-программер
****


Профиль
Группа: Участник Клуба
Сообщений: 7326
Регистрация: 11.5.2005
Где: Porto Franco Odes sa

Репутация: нет
Всего: 146



Код

SELECT * FROM tbl_name WHERE FIND_IN_SET('value',set_col)>0;



--------------------
Владение русской орфографией это как владение кунг-фу — истинные мастера не применяют его без надобности. 
smile

PM   Вверх
taral
Дата 22.10.2014, 13:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 230
Регистрация: 17.1.2008

Репутация: нет
Всего: нет



Цитата

SELECT * FROM tbl_name WHERE FIND_IN_SET('value',set_col)>0;

Такой способ запроса я знаю. В моем случае он не подойдет. Поскольку у меня 'value' не одно значение, а набор. Причем условие пройдет если любое из значений с таблицы будет в списке. Я выше все подробно описал. Спасибо за ответ.
PM MAIL   Вверх
Akina
Дата 22.10.2014, 15:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20580
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 106
Всего: 454



Если набор значений также поступает в виде списка - одним запросом это не решается.
Самый простой выход - слить искомые значения во временную таблицу, но по одному.
Самый правильный выход - нормализовать структуру БД и уйти от хранения CSV-set.


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MySQL | Следующая тема »


 




[ Время генерации скрипта: 0.0624 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.