Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP 5/6. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В. Программирование. Ступени успешной карьеры. Авторы: Кузнецов М.В., Симдянов И.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Mysql: переменное количество условий в запросе
 
 автор: makigo   (21.08.2011 в 13:28)   письмо автору
 
 

Здравствуйте.Я любитель и у меня задача которую немогу решить.
Из формы даем переменные для поиска из базы.

$product = $_POST['product'];
$store = $_POST['store'];
$brand= $_POST['brand'];

$query = " SELECT * FROM dat WHERE product='$product' and store='$store' and brand='$brand'";


Но в запросе надо использовать только те переменные, которые у нас вставлены.Или если скажем не вставлена переменная $store то чтобы при таком же $query игнорировал совпадение с store.

Помогите пожалуйста решить проблему.

  Ответить  
 
 автор: cheops   (21.08.2011 в 13:37)   письмо автору
 
   для: makigo   (21.08.2011 в 13:28)
 

В этом случае обычно формируют массив с условиями
<?php
  $sql 
= array();
  if(!empty(
$product)) $sql[] = "product='$product'";
  if(!empty(
$store)) $sql[] = "store='$store'";
  if(!empty(
$brand)) $sql[] = "brand='$brand'";
?>
а потом его преобразуют в строку при помощи implode()
<?php
  
if(!empty($sql)) $query "SELECT * FROM dat WHERE ".implode(" AND "$sql);
  else 
$query "SELECT * FROM dat";
?>

  Ответить  
 
 автор: makigo   (21.08.2011 в 13:39)   письмо автору
 
   для: cheops   (21.08.2011 в 13:37)
 

Большое спасибо!

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования