sql >> Databáze >  >> RDS >> Mysql

Dotaz na PHP/MySql A/NEBO pro pokročilé vyhledávání

Můžete zkontrolovat, která z polí jsou nastavena, a podle toho provést dotaz za běhu. něco takového můžete udělat:

$query = "";
$keyword = $_REQUEST['keyword'];
$country = $_REQUEST['country'];
$category = $_REQUEST['category'];
if(isset($keyword)){//if keyword set goes here
   $query = "SELECT * FROM table1 WHERE Name LIKE '%$keyword%' OR ZipCode LIKE '%$keyword%' OR country LIKE '%$keyword%'";
   if(isset($category)){
     $query .= "AND category LIKE '$category'";
   }
   if(isset($country)){
     $query . = "AND country LIKE '$country'"
   }
}else if (isset($category)){ //if keyword not set but category set then goes here
  $query = "SELECT * FROM table1 WHERE category LIKE '$category'";
  if(isset($country)){
    $query . = "AND country LIKE '$country'";
  }
}else if(isset($country)){//if only country set goes here
  $query = "SELECT * FROM table1 WHERE country LIKE '$country'"
}


  1. 2 způsoby, jak vrátit nečíselné hodnoty v SQLite

  2. Jak generovat příkazy INSERT z dotazu při použití SQLcl (Oracle)

  3. Proč je návrat MySQL vždy 1 v kódu C#, ale ne, když testuji v uložené proceduře?

  4. mysql týden od pondělí do neděle