入门客AI创业平台(我带你入门,你带我飞行)
博文笔记

Thinkphp3.2 中的where条件复杂条件下的条件组合

创建时间:2017-04-13 投稿人: 浏览次数:147

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

一、字符串模式查询

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

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

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

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

二、请求字符串查询方式

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

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

得到的查询条件是:

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

三、复合查询

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

  1. $where["name"] = array("like", "%thinkphp%");
  2. $where["title"] = array("like","%thinkphp%");
  3. $where["_logic"] = "or";
  4. $map["_complex"] = $where;
  5. $map["id"] = array("gt",1);

查询条件是

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

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

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

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


转载自thinkphp官网手册

声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。