从PHP中传递的值动态创建SQL语句

时间:2012-11-28 18:04:28

标签: php sql where

我将一些值传递给一个函数,然后想要创建一个SQL查询来在数据库中搜索这些值。

此输入是下拉框,这意味着输入可以是ALL或*我想要创建为通配符。

问题在于你无法做到:

$result = mysql_query("SELECT * FROM table WHERE something1='$something1' AND something2='*'") or die(mysql_error());

我已经开始了,但无法找出使它工作的逻辑循环。这就是我到目前为止所做的:

public function search($something1, $something2, $something3, $something4, $something5) {

    //create query
    $query = "SELECT * FROM users";

    if ($something1== null and $something2== null and $something3== null and $something4== null and $something5== null) {
        //search all users
        break 
    } else  {

        //append where
         $query = $query . " WHERE "; 

                if ($something1!= null) {
                    $query = $query . "something1='$something1'"
                }
                if ($something2!= null) {
                    $query = $query . "something2='$something2'"
                }
                if ($something3!= null) {
                    $query = $query . "something3='$something3'"
                }
                if ($something4!= null) {
                    $query = $query . "something4='$something4'"
                }
                if ($something5!= null) {
                    $query = $query . "something5='$something5'"
                }

    $uuid = uniqid('', true);

    $result = mysql_query($query) or die(mysql_error());
}

这个问题是它只能按顺序工作。如果某人首先输入例如某事物3,那么它就不会将AND添加到正确的位置。

非常感谢任何帮助。

3 个答案:

答案 0 :(得分:0)

我会做这样的事情

criteria = null
if ($something1!= null) {
      if($criteria != null)
      {
          $criteria = $criteria . " AND something1='$something1'"
      }
      else
      {
           $criteria = $criteria . " something1='$something1'"
      }
}
   ... other criteria


$query = $query . $criteria

答案 1 :(得分:0)

以下是动态构建WHERE子句的示例。我还展示了使用PDO和查询参数。您应该停止使用已弃用的mysql API并开始使用PDO。

public function search($something1, $something2, $something3, $something4, $something5)
{
    $terms = array();
    $values = array();

    if (isset($something1)) {
       $terms[] = "something1 = ?";
       $values[] = $something1;
    }

    if (isset($something2)) {
       $terms[] = "something2 = ?";
       $values[] = $something2;
    }

    if (isset($something3)) {
       $terms[] = "something3 = ?";
       $values[] = $something3;
    }

    if (isset($something4)) {
       $terms[] = "something4 = ?";
       $values[] = $something4;
    }

    if (isset($something5)) {
       $terms[] = "something5 = ?";
       $values[] = $something5;
    }

    $query = "SELECT * FROM users ";

    if ($terms) {
        $query .= " WHERE " . join(" AND ", $terms);
    }

    if (defined('DEBUG') && DEBUG==1) {
      print $query . "\n";
      print_r($values);
      exit();
    }

    $stmt = $pdo->prepare($query);
    if ($stmt === false) { die(print_r($pdo->errorInfo(), true)); }

    $status = $stmt->execute($values);
    if ($status === false) { die(print_r($stmt->errorInfo(), true)); }
}

我已经测试了上述内容并且有效。如果我为五个函数参数中的任何一个传递任何非null值,它只为非null的术语创建一个WHERE子句。

测试:

define('DEBUG', 1);
search('one', 'two', null, null, 'five');

此测试的输出是:

SELECT * FROM users  WHERE something1 = ? AND something2 = ? AND something5 = ?
Array
(
    [0] => one
    [1] => two
    [2] => five
)

如果您需要更加动态,请将数组传递给函数而不是单个参数。

答案 2 :(得分:0)

尝试使用数组。

 function search($somethings){

     $query = "SELECT * FROM users";           
     $filters = '';
     if(is_array($somethings)){

        $i = 0;
        foreach($somethings as $key => $value){
           $filters .= ($i > 0) ? " AND $key = '$value' " : " $key = '$value'";
           $i++;
        }
     }
     $uuid = uniqid('', true);
     $query .= $filters;
     $result = mysql_query($query) or die(mysql_error());
 }

 // demo
 $som = array(
      "something1" => "value1",
      "something2" => "value2"
 ); 

 search( $som );