admin 发表于 2018-9-14 13:13:08

where查询表达式

b、表达式查询
表达式        含义
EQ        等于(=)
NEQ        不等于(<>)
GT        大于(>)
EGT        大于等于(>=)
LT        小于(<)
ELT        小于等于(<=)
LIKE        模糊查询
BETWEEN        (不在)区间查询
IN        (不在)IN 查询
EXP        表达式查询,支持SQL语法


$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件
M("User")->where($where)->select();//查询status为0的记录

3、where方法数组查询例子
1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录

2、数组查询使用OR查询?比如,查询status等于0或者1的记录。
$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
M("User")->where($where)->select();//查询status等于0或者1的记录

3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
$where['createdate'] = array('EGT',"2016-04-20");
$where['status'] = '1';
$condition['_logic'] = "AND";
$map['_complex']=$where;
$map['level']='0';
$map['_logic']='OR';
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录
页: [1]
查看完整版本: where查询表达式