• ThinkPHP3.2.3框架下where的组合查询and、or方法


    在项目开发中,查询数据时经常用到where条件查询来过滤数据;

    有时就需要一个input输入框判断多个字段查询,这时候我们就需要使用组合查询方法来实现;

    说明:组合查询的主体还是采用数组方式查询,只是加入了一些特殊的查询支持,包括字符串模式查询(_string)、复合查询(_complex)、请求字符串查询(_query),混合查询中的特殊查询每次查询只能定义一个,由于采用数组的索引方式,索引相同的特殊查询会被覆盖。

    具体实现方法如下:

    字符串模式查询

     数组条件可以和字符串条件(采用_string 作为查询条件)混合使用,例如:

    $User = M("User"); // 实例化User对象
    $map['id'] = array('neq',1);
    $map['name'] = 'ok';
    $map['_string'] = 'status=1 AND score>10';
    $User->where($map)->select(); 

    最后得到的查询条件就成了:

    ( `id` != 1 ) AND ( `name` = 'ok' ) AND ( status=1 AND score>10 )

    请求字符串查询方式

    请求字符串查询是一种类似于URL传参的方式,可以支持简单的条件相等判断。

    $map['id'] = array('gt','100');
    $map['_query'] = 'status=1&score=100&_logic=or';

    得到的查询条件是:

    `id`>100 AND (`status` = '1' OR `score` = '100')

    复合查询

    复合查询相当于封装了一个新的查询条件,然后并入原来的查询条件之中,所以可以完成比较复杂的查询条件组装。 例如:

    $where['name']  = array('like', '%thinkphp%');
    $where['title']  = array('like','%thinkphp%');
    $where['_logic'] = 'or';
    $map['_complex'] = $where;
    $map['id']  = array('gt',1);

    查询条件是

    ( id > 1) AND ( ( name like '%thinkphp%') OR ( title like '%thinkphp%') )

    复合查询使用了_complex作为子查询条件来定义,配合之前的查询方式,可以非常灵活的制定更加复杂的查询条件。 很多查询方式可以相互转换,例如上面的查询条件可以改成:

    $where['id'] = array('gt',1);
    $where['_string'] = ' (name like "%thinkphp%")  OR ( title like "%thinkphp") ';

    最后生成的SQL语句是一致的。

  • 相关阅读:
    用TPLINK 无线网卡设置无线工作环境
    ChartDirector与JFreeChart两款主要web图表工具调研报告
    发现奇怪的问题,TOMCAT居然跟本机网卡的DNS设置有关
    解决Oracle监听器服务不能启动的问题
    JAVA 调用 .NET写的WEBSERVICE
    Windows Forms 实现安全的多线程详解
    异步调用与多线程
    关于.NET异步调用的初步总结
    c#中的多线程同步
    WinForm界面开发
  • 原文地址:https://www.cnblogs.com/wenzheshen/p/9317586.html
Copyright © 2020-2023  润新知