Thinkphp 查询条件 and 和 or同时使用即复合查询

举报
lxw1844912514 发表于 2022/03/28 00:33:06 2022/03/28
【摘要】   thinkphp 3.2快捷查询OR查询&分割表示AND查询讲解         快捷查询方式是一种多字段查询的简化写法,可以进一步简化查询条件的写法,在多个字段之间用|分割表示OR查询,用&分割表示AND查询,可以实现下面的查询,例如: &...

  thinkphp 3.2快捷查询OR查询&分割表示AND查询讲解

        快捷查询方式是一种多字段查询的简化写法,可以进一步简化查询条件的写法,在多个字段之间用|分割表示OR查询,用&分割表示AND查询,可以实现下面的查询,例如:
        一、不同字段相同的查询条件

            $User = M("User"); // 实例化User对象
            $map['name|title'] = 'thinkphp';
            // 把查询条件传入查询方法
            $User->where($map)->select();

        上面的查询其实可以等效于

            $User = M("User"); // 实例化User对象
            $map['name'] = 'thinkphp';
            $map['title'] = 'thinkphp';
            $map['_logic'] = 'OR';
            // 把查询条件传入查询方法
            $User->where($map)->select();

        查询条件就变成 name= 'thinkphp' OR title = 'thinkphp'
        二、不同字段不同的查询条件

            $User = M("User"); // 实例化User对象
            $map['status&title'] =array('1','thinkphp','_multi'=>true);
            // 把查询条件传入查询方法
            $User->where($map)->select();

        上面的查询等效于:

            $User = M("User"); // 实例化User对象
            $map['status'] = 1;
            $map['title'] = 'thinkphp';
            // 把查询条件传入查询方法
            $User->where($map)->select();

        '_multi'=>true必须加在数组的最后,表示当前是多条件匹配,这样查询条件就变成 status= 1 AND title = 'thinkphp'

        ,查询字段支持更多的,例如:

            $map['status&score&title'] =array('1',array('gt','0'),'thinkphp','_multi'=>true);

        等效于:

            $map['status'] = 1;
            $map['score'] = array('gt',0);
            $map['title'] = 'thinkphp';

        查询条件就变成 status= 1 AND score >0 AND title = 'thinkphp'

            注意:快捷查询方式中“|”和“&”不能同时使用。

文章来源: blog.csdn.net,作者:lxw1844912514,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/lxw1844912514/article/details/100028884

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。