多个查询条件的sql语句的拼写技巧,求指点。
$sql="select * from tb1";
if($id=$_GET['id'])
{
$where.=" where id like "%$id%"";
}
if($name=$_GET['name'])
{
$where.=" where name like "%$name%"";
}//当id有值的时候
sql=select * from tb1 where id like "%$id%"
//当name有值的时候
sql=select * from tb1 where name like "%$name%"//当同时又值的时候,sql就出错了
sql=select * from tb1 where name like "%$name%" where where id like "%$id%" //当然你可以说用
if($id=$_GET['id']&&$name=$_GET['name'])
{
where.= "and";
}我举的例子只有两个条件,实际项目中我这里有十几个条件,这种方式肯定不行。
求更好的拼接方式

解决方案 »

  1.   

    $where = array();
    foreach($_GET as $k=>v) $where[] = "$k like '%$v%'";
    $sql="select * from tb1";
    if($where) $sql .= ' where ' . join(' and ', $where);
      

  2.   

    $sql="select * from tb1";
    $where = array();
    if($id=$_GET['id'])
    {
        $where[]=" id like '%$id%'";
    }
    if($name=$_GET['name'])
    {
        $where[]=" name like '%$name%'";
    }$s=(!empty($where)) ? " where " . implode(" and " , $where) : '';
    $sql.=$s;
      

  3.   

    我个人觉得我这个简单
    $sql="select * from tb1 where 1=1";
    if($id=$_GET['id']) $sql.=" and id like "%$id%"";
    if($name=$_GET['name']) $sql.=" and name like "%$name%"";