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

Форум MySQL

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

 

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

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

тема: Выборка всех записей...
 
 автор: Front   (17.11.2006 в 17:07)   письмо автору
 
 

Привет softtimoвцы, горит, короче есть таблица kvarts содержащая три столбца agentid, mkomn, area. Есть форма поиска с select по этим трем столцам, делаю запрос:

$query="select * from kvarts where (agentid='$agentid' and mkomn='$mkomn' and area like '$area%')";

Выборку он делает в соответствии со значениями выбранными в форме, а как в форме задать такие значения чтобы в результате запроса выводились все записи таблицы?

Заранее благодарен за помощь....

   
 
 автор: aexb   (17.11.2006 в 19:52)   письмо автору
 
   для: Front   (17.11.2006 в 17:07)
 

Не совсем понятно, что требуется. Если нужно выбрать ВСЕ записи из таблицы, то оставьте просто

<?
$sql
=mysql_query("SELECT * FROM KVARTS");
?>

   
 
 автор: Front   (20.11.2006 в 10:22)   письмо автору
 
   для: aexb   (17.11.2006 в 19:52)
 

Да это понятно, дело в том, что форма это форма поиска, если сделать запрос
select * from kvarts where (agentid='$agentid' and mkomn='$mkomn' and area like '$area%'), где agentid, mkomn и area данные из формы, при этом задав их, по базе он ищет. Хочется сделать так чтобы когда в форме никакие критерии не выбирались, после нажатия поиск он выдавал все строки в базе.?
Я так понимаю что для начала нужно проверить, пустые они или нет...?

   
 
 автор: Trianon   (20.11.2006 в 10:55)   письмо автору
 
   для: Front   (20.11.2006 в 10:22)
 

<?
  $query
="select * from kvarts"
  
$sep " where";
  if(!empty(
$agentid))  { $query .= "$sep agentid='$agentid'"$sep ' and'; }
  if(!empty(
$mkomn))    { $query .= "$sep mkomn='$mkomn'"$sep ' and'; }
  if(!empty(
$area))     { $query .= "$sep area like mkomn='%$area%'"$sep ' and'; }
?>

   
 
 автор: Front   (20.11.2006 в 12:34)   письмо автору
 
   для: Trianon   (20.11.2006 в 10:55)
 

Большое спасибо, все заработало.
Не подскажете, еще один вопрос.
В базе есть столбец float (4.1) c именем sall, в форме есть select
<SELECT NAME="sall">
<OPTION value="100.0">100.0</OPTION>
</select>

Делаю запрос
if (!empty($_POST['sall']))
$query .= " AND sall<'$sall'";
Результат:
Supplied argument is not a valid MySQL result resource

Как сравнить?
p.S. По поводу DECIMAL знаю, хочется разобраться с float
Заренее благодарен...

   
 
 автор: elenaki   (20.11.2006 в 12:37)   письмо автору
 
   для: Front   (20.11.2006 в 12:34)
 

кажется, там не нужны кавычки


$query .= " AND sall<$sall";

   
 
 автор: Front   (20.11.2006 в 12:52)   письмо автору
 
   для: elenaki   (20.11.2006 в 12:37)
 

Не спасает та же ошибка...

   
 
 автор: Trianon   (20.11.2006 в 13:03)   письмо автору
 
   для: Front   (20.11.2006 в 12:34)
 

а где весь запрос?

   
 
 автор: Front   (20.11.2006 в 13:24)   письмо автору
 
   для: Trianon   (20.11.2006 в 13:03)
 

$query = "SELECT * FROM kvarts";
if (!empty($_POST['agentid']))
$query .= " WHERE agentid='$agentid'";
if (!empty($_POST['mkomn']))
$query .= " AND mkomn='$mkomn'";
if (!empty($_POST['area']))
$query .= " AND area='$area'";
if (!empty($_POST['floor']))
$query .= " AND floor='$floor'";
if (!empty($_POST['sall']))
$query .= " AND sall<$sall";

   
 
 автор: Trianon   (20.11.2006 в 13:42)   письмо автору
 
   для: Front   (20.11.2006 в 13:24)
 

Так не выйдет.
Я не ради красоты вводил переменную $sep.

   
 
 автор: Front   (20.11.2006 в 14:02)   письмо автору
 
   для: Trianon   (20.11.2006 в 13:42)
 

То есть без переменной $sep поиск по float не будет работать, т.к. без sall запрос:
$query = "SELECT * FROM kvarts";
if (!empty($_POST['agentid']))
$query .= " WHERE agentid='$agentid'";
if (!empty($_POST['mkomn']))
$query .= " AND mkomn='$mkomn'";
if (!empty($_POST['area']))
$query .= " AND area='$area'";
if (!empty($_POST['floor']))
$query .= " AND floor='$floor'";

Работает....

Код:

<?php
@$db = mysql_pconnect ("","","");
if (!$db)
{
echo "Соединение с базой прервано. Попробуйте еще раз.";
exit;
}
mysql_select_db("kvartira");
$query="select * from kvarts"
$sep = " where";
if (!empty($_POST['agentid'])) { $query .= "$sep agentid='$agentid'"; $sep = ' and'; }
if(!empty($mkomn)) { $query .= "$sep mkomn='$mkomn'"; $sep = ' and'; }
if(!empty($area)) { $query .= "$sep area like '$area%'"; $sep = ' and'; }
if(!empty($floor)) { $query .= "$sep floor='$floor'"; $sep = ' and'; }
if(!empty($sall)) { $query .= "$sep sall<'$sall'"; $sep = ' and'; }
$result = mysql_query($query);
$num_results = mysql_num_rows ($result);
echo "<table border=1 align=center cellpadding=5 cellspacing=0>";
echo "<tr>";
echo "<td class=2 align=center><b>№</b></td>";
echo "<td class=2 align=center><b>Номер агента</b></td>";
echo "<td class=2 align=center><b>Количество комнат</b></td>";
echo "<td class=2 align=center><b>Район</b></td>";
echo "<td class=2 align=center><b>Адрес</b></td>";
echo "<td class=2 align=center><b>Этаж</b></td>";
echo "<td class=2 align=center><b>Общая площадь</b></td>";
echo "<td class=2 align=center><b>Жилая площадь</b></td>";
echo "<td class=2 align=center><b>Кухня</b></td>";
echo "<td class=2 align=center><b>Метро</b></td>";
echo "<td class=2 align=center><b>Телефон</b></td>";
echo "<td class=2 align=center><b>Тип дома</b></td>";
echo "<td class=2 align=center><b>Санузел</b></td>";
echo "<td class=2 align=center><b>Цена</b></td>";
echo "<td class=2 align=center><b>Дополнительно</b></td>";
echo "<td class=2 align=center><b>Использование в коммерческих целях</b></td>";
echo "<td class=2 align=center><b>Договор</b></td>";
echo "<td class=2 align=center><b>Смотрел</b></td>";
echo "<td class=2 align=center><b>Сумма коммисионных_1</b></td>";
echo "<td class=2 align=center><b>Сумма коммисионных_2</b></td></tr>";
for ($i=0; $i < $num_results; $i++)
{
$arr_quest=mysql_fetch_array ($result);
echo "<tr>";
echo "<td class=3>".$arr_quest["objectid"]."</td>";
echo "<td class=3>".$arr_quest["agentid"]."</td>";
echo "<td class=3>".$arr_quest["mkomn"]."</td>";
echo "<td class=3>".$arr_quest["area"]."</td>";
echo "<td class=3>".$arr_quest["address"]."</td>";
echo "<td class=3>".$arr_quest["floor"]."</td>";
echo "<td class=3>".$arr_quest["sall"]."</td>";
echo "<td class=3>".$arr_quest["slive"]."</td>";
echo "<td class=3>".$arr_quest["kitchen"]."</td>";
echo "<td class=3>".$arr_quest["metro"]."</td>";
echo "<td class=3>".$arr_quest["phone"]."</td>";
echo "<td class=3>".$arr_quest["house"]."</td>";
echo "<td class=3>".$arr_quest["wc"]."</td>";
echo "<td class=3>".$arr_quest["price"]."</td>";
echo "<td class=3>".$arr_quest["dop"]."</td>";
echo "<td class=3>".$arr_quest["purpose"]."</td>";
echo "<td class=3>".$arr_quest["contract"]."</td>";
echo "<td class=3>".$arr_quest["see"]."</td>";
echo "<td class=3>".$arr_quest["giftag"]."</td>";
echo "<td class=3>".$arr_quest["giftpr"]."</td></tr>";
};
echo "</td></tr>";
echo "</table>";
?>

В этом случае выдает ошибку синтаксиса...

   
 
 автор: Trianon   (20.11.2006 в 14:26)   письмо автору
 
   для: Front   (20.11.2006 в 14:02)
 


$query = "SELECT * FROM kvarts"; 
if (!empty($_POST['agentid'])) 
$query .= " WHERE agentid='$agentid'"; 
if (!empty($_POST['mkomn'])) 
$query .= " AND mkomn='$mkomn'"; 
if (!empty($_POST['area'])) 
$query .= " AND area='$area'"; 
if (!empty($_POST['floor'])) 
$query .= " AND floor='$floor'";

Работает....

Нет. Не работает. Попробуйте оставить agentid пустым - сразу увидите.

   
 
 автор: Front   (20.11.2006 в 14:47)   письмо автору
 
   для: Trianon   (20.11.2006 в 14:26)
 

Слушайте, не знаю в чем дело, но при выборе пустого значения agentid выдает всю базу, если выбираешь конкретный номер выдает его...
Может посмотрите чего в основном запросе неправильно...?

   
 
 автор: Trianon   (20.11.2006 в 15:39)   письмо автору
 
   для: Front   (20.11.2006 в 14:47)
 

Уберите апострофы вокруг $sall. Это же число, не так ли?

   
 
 автор: Front   (20.11.2006 в 13:53)   письмо автору
 
   для: Trianon   (20.11.2006 в 10:55)
 

Все заработало, огромное всем спасибо... :-))

Получился вот такой запрос:
$where[] = "1=1";
if(!empty($_POST['agentid'])) $where[] = "agentid = ".$_POST['agentid'];
if(!empty($_POST['mkomn'])) $where[] = "mkomn = ".$_POST['mkomn'];
if(!empty($_POST['area'])) $where[] = "area = '".$_POST['area'];
if(!empty($_POST['floor'])) $where[] = "floor = '".$_POST['floor'];
if(!empty($_POST['sall'])) $where[] = "sall > '".$_POST['sall']."'";
$query = "SELECT * FROM kvarts WHERE ".implode(" AND ",$where);

А что такое implode?

   
Rambler's Top100
вверх

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