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]   

> Описание: Как использовать массив для поиска в БД?
SidneyShow
Отправлено: 21 Июля, 2016 - 13:13:51
Post Id


Новичок


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


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




Здравствуйте дорогие участники этого форума.
Вообщем у меня есть массив в котором, например:

$Year[0] => 1990;
$Year[1] => 1991;
$Year[2] => 1992;
и т.д.

Далее мне необходимо извлечь из БД информацию используя этот массив, и я делаю это так:

$Row = mysqli_query($CONNECT, "SELECT `id` FROM users WHERE year = '$Year[0]' OR year = '$Year[1]' OR year = '$Year[2]')";

Но это очень не удобно(так как значение из массива очень много), можно ли как то в запросе к БД указать лишь одну переменную, но что бы смысл запроса остался тем же?
 
 Top
OrmaJever Модератор
Отправлено: 21 Июля, 2016 - 14:51:19
Post Id



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


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


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




PHP:
скопировать код в буфер обмена
  1. $Row = mysqli_query($CONNECT, "SELECT `id` FROM users WHERE year in (".join(',', $Year).")";

Но вы должны быть уверены что в $Year безопасные значения.
(Добавление)
а еще есть такая штука как between, погуглите, возможно подойдет


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
SidneyShow
Отправлено: 22 Июля, 2016 - 13:21:53
Post Id


Новичок


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


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




OrmaJever пишет:
PHP:
скопировать код в буфер обмена
  1. $Row = mysqli_query($CONNECT, "SELECT `id` FROM users WHERE year in (".join(',', $Year).")";

Но вы должны быть уверены что в $Year безопасные значения.
(Добавление)
а еще есть такая штука как between, погуглите, возможно подойдет

Большое спасибо за помощь, это то что нужно Радость
 
 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