Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Запрос к полю

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
pantela
Отправлено: 04 Октября, 2010 - 10:19:56
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 765
Дата рег-ции: Авг. 2010  


Помог: 1 раз(а)




В таблице есть поле cb_spec,

Есть 3 данные
У которых вписанно
1)

2)
CODE (SQL):
скопировать код в буфер обмена
  1. Значение1|*|Значение2

3)
CODE (SQL):
скопировать код в буфер обмена
  1. Значение1|*|Значение2|*|Значение3


Делаю запрос для вывода:
PHP:
скопировать код в буфер обмена
  1. `cb_spec` ='Значение1' OR `cb_spec` ='Значение2' OR `cb_spec` ='Значение3'


Но при этом ничего не выводится

т.е. Мне надо что бы игнорирование происходило бы на |*| т.е. что между ними то что бы и читалось как новое значение в поле.

(Отредактировано автором: 04 Октября, 2010 - 10:20:38)

 
 Top
EuGen Администратор
Отправлено: 04 Октября, 2010 - 10:24:37
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)




Так делать - архитектурно неправильно. Создайте таблицу-связку для Вашего поля и туда записывайте Ваши значения. А определяйте наличие с помощью присоединения (JOIN)


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
pantela
Отправлено: 04 Октября, 2010 - 10:42:37
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 765
Дата рег-ции: Авг. 2010  


Помог: 1 раз(а)




EuGen пишет:
Так делать - архитектурно неправильно. Создайте таблицу-связку для Вашего поля и туда записывайте Ваши значения. А определяйте наличие с помощью присоединения (JOIN)


спс. Конечно но у меня это всё в компоненте Joomla (Communication Builder)
Там есть пользоватлеи которым я поздал поле и просвоил эти значения, далле создал List Manager и для вывода этих пользователей делаю фильтрацию, вот и туту трабла сней.

Так вот через 1 запрос можно как нибудь построить токое. Растерялся
 
 Top
JustUserR
Отправлено: 04 Октября, 2010 - 23:23:30
Post Id



Активный участник


Покинул форум
Сообщений всего: 8715
Дата рег-ции: Июнь 2009  


Помог: 17 раз(а)




pantela пишет:
Делаю запрос для вывода:
В случае если используемое вами WHERE-условие в SQL-запросе содержит несколько критериев сравнения применяемых для одного информационного поля - то такой набор элементов возможно объединить в общий IN-оператор Кроме того при создлании внешних и рефлексивных соединения таблицы - внутренний оптимизатор SQL-запросов как правило приводит операции JOIN-соединения в набор вложенных конструкуий или процедурный код


-----
Сделать можно все что угодно - нужно только старание, терпение и хороший поисковик Улыбка
Безлимитный web-хостинг от 15 рублей за 40 МБ дискового пространства - http://ihost[dot]oks71[dot]ru/
 
 Top
pantela
Отправлено: 05 Октября, 2010 - 01:12:13
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 765
Дата рег-ции: Авг. 2010  


Помог: 1 раз(а)




Понимаю что через JOIN можно, просто тут всё в компоненте встроенно а переписывать комопнент большое геморой.

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

PHP:
скопировать код в буфер обмена
  1. SELECT ... WHERE field="2" OR field="3" OR field="4"...


Определлся в базе где данное в поле вводится так: 2|*|3|*|4

т.е. то что после и до |*| что бы было бы как отдельное данное для поля.
 
 Top
Мелкий Супермодератор
Отправлено: 05 Октября, 2010 - 01:26:25
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




Можно сделать типа так: where (`field` like "$value|*%" or `field` like "%*|$value|*%" or `field` like "%*|$value")
т.е. сравнение строк.

Но лучше не мучить мозг базе и себе и выкинуть этот компонент.

(Отредактировано автором: 05 Октября, 2010 - 01:27:28)



-----
PostgreSQL DBA
 
 Top
JustUserR
Отправлено: 06 Октября, 2010 - 12:58:22
Post Id



Активный участник


Покинул форум
Сообщений всего: 8715
Дата рег-ции: Июнь 2009  


Помог: 17 раз(а)




pantela пишет:
Определлся в базе где данное в поле вводится так
Возможности процедурной обработки СУБД в виде систем типа PL/SQL позволяют осуществлять разбор инофрмационных полей - передача которых происходит в открытом или кодированном виде с набором разделяющих элементов - однако такой подход не является оптимальным и не учитываеет правила нормализации представлений в БД


-----
Сделать можно все что угодно - нужно только старание, терпение и хороший поисковик Улыбка
Безлимитный web-хостинг от 15 рублей за 40 МБ дискового пространства - http://ihost[dot]oks71[dot]ru/
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Программирование на PHP »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB