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 :: Array in mysql

 PHP.SU

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


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

> Без описания
VestCoastman
Отправлено: 25 Августа, 2013 - 03:58:46
Post Id



Посетитель


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


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




Допустим есть массив чисел через запятую, которые хранятся в поле mysql - 3,5,1,2,14,17(Пусть это поле называется my_array)
У меня 2 вопроса.
1. В каком типе данных хранить такого вида запись? Varchar?
2. Как будет выглядеть запрос, если проверка будет идти только на одно значение из этого массива(пример ниже)?
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT id,my_array FROM TABLE WHERE id=$num AND $var IN (my_array)

Такой запрос естественно неверный Улыбка
(Добавление)
Остался только первый вопрос.
Со вторым вопросом разобрался.
Решение:
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT id,my_array FROM TABLE WHERE id=$num AND CONCAT(',',my_array,',') LIKE '%,$var,%'

(Отредактировано автором: 25 Августа, 2013 - 04:15:00)

 
 Top
DeepVarvar Супермодератор
Отправлено: 25 Августа, 2013 - 05:13:01
Post Id



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


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


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




Это ужаснейший костыль. Делайте отдельную таблицу связей.
 
 Top
VestCoastman
Отправлено: 25 Августа, 2013 - 08:11:13
Post Id



Посетитель


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


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




Да я тут подумываю о том, чтобы вообще всё в кэшевые файлы запихнуть... Ведь таблицы обновляются только по определенным событиям, следовательно зачем нагружать базу подобными запросами...
Тут тогда придется не отдельную таблицу делать, а отдельный файл кэша.
 
 Top
caballero
Отправлено: 25 Августа, 2013 - 10:30:46
Post Id


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


Покинул форум
Сообщений всего: 5998
Дата рег-ции: Сент. 2011  
Откуда: Харьков


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




Цитата:
Да я тут подумываю о том, чтобы вообще всё в кэшевые файлы запихнуть.

это просто другой костыль

используйте Бд по человечески. Она сама закеширует наиболее часто считываемые данные


-----
Бесплатная система складского учета с открытым кодом https://zippy[dot]com[dot]ua/zstore
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB