多个查询条件的sql语句的拼写技巧,求指点。

caikeqiang168 2013-08-19 03:28:45
多个查询条件的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";
}

我举的例子只有两个条件,实际项目中我这里有十几个条件,这种方式肯定不行。
求更好的拼接方式
...全文
142 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
feraner 2013-08-20
  • 打赏
  • 举报
回复
引用 3 楼 baoxiaohua 的回复:
我个人觉得我这个简单

$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%"";
你这个只是直白 没2#的好啊 但都是高手啊
baoxiaohua 2013-08-19
  • 打赏
  • 举报
回复
我个人觉得我这个简单

$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%"";
一起混吧 2013-08-19
  • 打赏
  • 举报
回复
$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;
xuzuning 2013-08-19
  • 打赏
  • 举报
回复
$where = array();
foreach($_GET as $k=>v) $where[] = "$k like '%$v%'";
$sql="select * from tb1";
if($where) $sql .= ' where ' . join(' and ', $where);

21,886

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧