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();

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

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网