thinkphp where有多个条件进行复合查询,关系为or,代码如下

有两个条件进行复合查询,关系为or
$where1=array(
'Key'=>array('like','zt'.'%'),
'code'=>'02'
);
$where2=array(
'modes'=>1,
'Key'=>array('like','tm'.'%'),
'code'=>'02'
);
//$where1与$where2为or,两者之内为and关系

$mysql=M('Mysql')->where(?)->select();
/*需要结果等同以下,要求一次查询
$mysql1=M('Odds')->where($where1)->select();
$mysql2=M('Odds')->where($where2)->select();
$mysql=array_merge($mysql1,$mysql2);
*/

请参考thinkphp开发手册的查询语言一节,可以有不同写法,我这里写一种供你参考:

$where1=array(
    'Key'=>array('like','zt'.'%'),
    'code'=>'02'
);
$where=array(
    'modes'=>1,
    'Key'=>array('like','tm'.'%'),
    'code'=>'02',
    '_complex'=>$where1, // 复合查询
    '_logic'=>'or'       // 关系为or
);
// 查询语句
$mysql=M('Mysql')->where($where)->select();

温馨提示:答案为网友推荐,仅供参考
相似回答