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

Форум PHP

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

 

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

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

тема: Сформировать запрос
 
 автор: Trunk   (01.08.2010 в 20:01)   письмо автору
 
 

Давненько не писал на php, вот появилась такая производственная необходимость :)

Скрипту передаются ($_GET) 4 параметра,
$smp, $control, $start, $end,
ниодин их необязателен.

Нужно составить SQL запрос, придумал такой "костыль" на первое время, но хочется более изящного решения

$first = true;
if ($action == "search")
{

$sql = "SELECT * FROM register WHERE ";
if (!empty($smp))
{
$sql .= "smp = \"".$smp."\" ";
$first = false;
}
if (!empty($control))
{
if (!$first) $sql .=" and ";
$sql .= "control = \"".$control."\"";
$first = false;
}
if (!empty($start))
{
if (!$first) $sql .=" and ";
$sql .= "start < \"".$start."\"";
$first = false;
}
if (!empty($end))
{
if (!$first) $sql .=" and ";
$sql .= "end > \"".$end."\"";
$first = false;
}
$sql .= " ORDER by `smp`;";
}

  Ответить  
 
 автор: neadekvat   (01.08.2010 в 20:53)   письмо автору
 
   для: Trunk   (01.08.2010 в 20:01)
 

Ну хоть бы в бб "code" оформили
Предлагаю примерно такое (предполагается, что переменные существуют, пусть даже пустой строкой, и обработаны для защиты от sql-inj.
<?php
if (!empty($param))
     
$sql[] = $param;

if (!empty(
$param_two))
     
$sql[] = $param_two;

...

$sql = isset($sql) ? implode(' AND '$sql) : null;

$query "SELECT ... WHERE 1 $sql";

  Ответить  
 
 автор: TrunK   (01.08.2010 в 21:15)   письмо автору
 
   для: neadekvat   (01.08.2010 в 20:53)
 

Большое спасибо!
Как-то не пришел в голову такой красивый ход!

ps: про бб совсем забыл, каюсь, давно не был на форуме

  Ответить  
 
 автор: sim5   (01.08.2010 в 22:44)   письмо автору
 
   для: neadekvat   (01.08.2010 в 20:53)
 

Проще тогда массив GET сразу обработать.

  Ответить  
 
 автор: neadekvat   (01.08.2010 в 22:55)   письмо автору
 
   для: sim5   (01.08.2010 в 22:44)
 

Вы хотели сказать, суперглобальный массив с исходными данными :)
Да, так, пожалуй, будет лучше, дабы не плодить переменных и уменьшить кол-во строк

  Ответить  
 
 автор: sim5   (01.08.2010 в 23:25)   письмо автору
 
   для: neadekvat   (01.08.2010 в 22:55)
 

А кто его знает, может и о суперлокалном GET. А что, есть такой? ;-)

  Ответить  
 
 автор: neadekvat   (01.08.2010 в 23:33)   письмо автору
 
   для: sim5   (01.08.2010 в 23:25)
 

Не, просто данные могут приходить и через POST и другие средства :)

  Ответить  
 
 автор: sim5   (02.08.2010 в 00:04)   письмо автору
 
   для: neadekvat   (01.08.2010 в 23:33)
 

Автор: ....Скрипту передаются ($_GET) 4 параметра

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

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