sql语句where条件的数组形式写法

本文详细解析了ThinkPHP框架中查询构造器的高级用法,包括数组形式的查询条件设置,如逻辑运算、范围查询、模糊匹配等,并介绍了特殊查询模式及SQL表达式的使用方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近看了下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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值