mysql多重条件查询,关于mysql多重组合查询的一点技巧总结

今天项目遇到了一个很有意思的问题:

就是一个搜索框,我们有6个搜索项目,

然后需要实现1个查询,2个查询,3个。。。一直到6个查询为止

开始我直接一眼的思路就是用N多的if()

$info = $_POST;

if(isset($info['xxx'])){

$sql = "select * from tablename where xxxx";

}else if(isset($info['xxxx'])){

}

......

?>

这大概要写6*5*4*3*2*1个if()

然后找了一下资料,发现可以这么写

$info = I('post.');

//根据条件写判断

$sql = "select * from ordertable where 1=1";

if($info['warehouse']){

$sql = $sql." and MarketId = ".$info['warehouse'];

}

if($info['Createtime']){

$sql = $sql." and Createtime = ".$info['Createtime'];

}

if($info['Paytime']){

$sql = $sql." and Paytime = ".$info['Paytime'];

}

if($info['Paystatus']){

$sql = $sql." and Paystatus = ".$info['Paystatus'];

}

if($info['orderNum']){

$sql = $sql." and orderNum = ".$info['orderNum'];

}

if($info['Product']){

$sql = $sql." and Product = ".$info['Product'];

}

?>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值