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

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

  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’

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/112869.html原文链接:https://javaforall.net

(0)
上一篇 2021年10月28日 下午7:00
下一篇 2021年10月28日 下午8:00


相关推荐

  • OpenClaw保姆级别安装教程,小白也可以养好自己的小龙虾

    OpenClaw保姆级别安装教程,小白也可以养好自己的小龙虾

    2026年3月14日
    2
  • JS简单实现图片上一张下一张操作

    简单实现了js的图片上一张下一张效果,没怎么做css美化单纯就是想记录一下js部分。效果图:嘿嘿,wuli爽妹子镇图!! <!DOCTYPEhtml><html><headlang="en"><metacharset="UTF-8"><title>幻灯片</title&

    2022年4月5日
    118
  • .net core实现aop_redis实时计算

    .net core实现aop_redis实时计算引言  最近工作上有需要使用redis,于是便心血来潮打算自己写一个C#客户端。经过几天的努力,目前该客户端已经基本成型,下面简单介绍一下。通信协议  要想自行实现redisClient,则必须先要了解Redis的socket能信协议。新版统一请求协议在Redis1.2版本中引入,并最终在Redis2.0版本成为Redis服务器通…

    2022年10月12日
    7
  • 查看sqlserver的端口号

    查看sqlserver的端口号背景 这几天想写一个使用 java 连接 sqlserver 的数据库连接测试程序 但是在查看数据库连接字符格式以后发现需要 sqlserver 数据库服务的端口号 在安装 sqlserver 的时候也没有提到端

    2026年3月26日
    2
  • mysql不执行命令_linux mysql启动命令

    mysql不执行命令_linux mysql启动命令Linux下使用mysql命令需要配置好环境以及各种文件,下面由学习啦小编为大家整理了linux下mysql命令不能用的相关知识,希望对大家有帮助!linux的mysql命令没用解决方法1.重新安装mysql命令,方法步骤如下:一安装步骤从这里下载你需要的版本(注意选择你操作系统是64位的还是32位的):这里只介绍两种判断linux是64位还是32的方法:命令:file/bin/cat[roo…

    2025年12月3日
    4
  • Manus如何拿下国内用户?

    Manus如何拿下国内用户?

    2026年3月15日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号