Пустое значение в Mysql

программирование php MySQL базы данных

WHERE `table1`='$1' AND `table2`='$2' AND `table3`='3'

Подскажите, если в переменной $1 есть значение. а в переменных $2 и $3 нет значения, то что нужно указать в переменных $2 и $3 чтобы выводил все значения из этих ячеек, а искал только по переменной которая существует ?!
Спасибо !

Примечание:
То есть, если у меня будет написано WHERE `table1`='$1' AND `table2`='IS NULL' AND `table3`='IS NULL'

Выберутся все значения в table2 и table3, так ?

Примечание:
Есть форма ввода поиска по базе и в переменные должны быть либо пусты, либо имеют значение. Когда есть значение в переменных, то поиск по базе хорошо проходит, но вот когда переменные $2 и $3 пустые, поиска не происходит. Что по умолчанию поставить в них ? Или написать функцию, что если есть в этой переменной что-то, то искать по where такому-то, если в другой есть то по другому where.
Ответы:
Пустое значение называется Null
чтобы его найти нужно указать
Where Field is null
is null тут не причем, `table2` IS NULL выбери из `table2` ячейки с значением NULL. вам нужно запрос формировать динамически, чтобы "пустые" переменные не попадали в запрос. т.е., если $2 и $3 пустые, запрос должен иметь вид WHERE `table1`='$1'.
в общем виде:
$query = 'select ... from ... were ';
foreach($_POST as $label => $item) {
   if ($item !== '')  {
       $query .= "`{$label}` = {$item} and ";
   }
}
$result = mysql_query(rtrim($query, ' and'));
...


11 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.