Mysql
 sql >> база данни >  >> RDS >> Mysql

динамично създаване на низ за търсене в mysql?

Това е бърз пример. Не знам какъв тип данни връща JRequest::getVar (винаги низ или смесени типове?), но това трябва да ви започне. Уверете се, че използвате който и да е метод за екраниране, приложим в рамките на цикъла foreach:

if ($post) {
    $criteria = array();
    //get all search variables
    $criteria['type'] = JRequest::getVar('type');
    $criteria['classifications'] = JRequest::getVar('classifications', array(0), 'post', 'array');
    $criteria['rating'] = JRequest::getVar('rating');

    //if there are some criteria, make an array of fieldName=>Value maps
    if(!empty($criteria)) {
        $where = array();
        foreach($criteria as $k => $v) {
            //IMPORTANT!!
            //$v is the value of the field, needs to be quoted correctly!!
            $where[] = "$k = '$v'";
        }
    }
    //create search string
    $query =  "SELECT * FROM #__db_clients";

    if($where) {
        $query .= " where " . join(' AND ', $where);
    }   
} else {    
    echo 'There has been an error, please try again.';
};



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Mysql разделяне и присъединяване

  2. Липсващ резултат в задължителните полета

  3. MySQL:Обединение на ляво присъединяване с дясно присъединяване

  4. Полетата на Jooq LocalDateTime използват системна часова зона вместо часова зона на сесията

  5. Сериализацията на 'Closure' не е разрешена - laravel