ThinkPHP where方法详解
1、字符串查询
1 | M("User")->where('status=0')->select();//查询status为0的记录 |
2、数组查询
a、普通查询
1 | $where['status'] = 0;//字段就是数组的下标,值就是对应的条件 |
注意:数组的下标必须为数据库的字段,否则会被过滤。
b、表达式查询
表达式 | 含义 |
---|---|
EQ | 等于(=) |
NEQ | 不等于(<>) |
GT | 大于(>) |
EGT | 大于等于(>=) |
LT | 小于(<) |
ELT | 小于等于(<=) |
LIKE | 模糊查询 |
[NOT] BETWEEN | (不在)区间查询 |
[NOT] IN | (不在)IN 查询 |
EXP | 表达式查询,支持SQL语法 |
1 | $where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件 |
3、where方法数组查询例子
1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
1 | $where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件 |
2、数组查询使用OR查询?比如,查询status等于0或者1的记录。
1 | $where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件 |
3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
1 | $where['createdate'] = array('EGT',"2016-04-20"); |