最近看了下tp,想到把它的查询条件写成数组形式,稍微总结了一下。where条件写成数组形式:
public function test(){
$where1=array(
'trade_no'=>'435363',
'out_trade_no'=>'435363',
'_logic'=>'or',
);
$a='bbbvcccd';
$b=3;
$where=array(
'order_sn'=>'123456',
'order_status'=>array('lt',$b),//大于gt,小于lt
'pay_time'=>array('between','1,2'),
'order_id'=>array('in','12,13,14'),
'order_uid'=>array('like','%'.$a.'%'),
'_complex'=>$where1,
);
M('order')->where($where)->select();
echo M()->getLastSql();
}
打印后的sql语句:SELECT * FROM `order` WHERE `order_sn` = '123456' AND `order_status` < 3 AND `pay_time` BETWEEN '1' AND '2' AND `order_id` IN ('12','13','14') AND `order_uid` LIKE '%bbbvcccd%' AND ( `trade_no` = '435363' OR `out_trade_no` = '435363' )
对于特殊的语句,可以用特殊的模式查询,包括字符串模式查询(_string
)、复合查询(_complex
)、请求字符串查询(_query
),如:$map['_query'] = 'status=1&score=100&_logic=or';
对于is not null 的语句,可以使用exp表达式,它支持任何的sql语句。
public function test2(){
$where1=array(
'status'=>0,
'org_id'=>'',
'phone'=>array('exp','is not null'),
'is_del'=>0,
);
$where=array(
'_string'=>'status=1 and partner_id is not null and is_del=0',
'_complex'=>$where1,
'_logic'=>'or',
);
$count=M('member')->where($where)->select();
}
附上一张关系运算符表:
表达式 | 含义 | 协助记忆 |
---|---|---|
EQ | 等于(=) | equal |
NEQ | 不等于(<>) | not equal |
GT | 大于(>) | greater |
EGT | 大于等于(>=) | equal or greater |
LT | 小于(<) | less than |
ELT | 小于等于(<=) | equal or less than |
LIKE | 模糊查询 | |
[NOT] BETWEEN | (不在)区间查询 | |
[NOT] IN | (不在)IN 查询 | |
EXP | 表达式查询,支持SQL语法 | expression |