sql语句where条件的数组形式写法
最近看了下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();
sql语句查询不包含echo M()->getLastSql();
}
打印后的sql语句:SELECT * FROM `order` WHERE `order_sn` = '123456' AND `order_status` < 3 A
ND `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
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论