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

大理石平台v型架

一、字符串模式查询

数组条件可以和字符串条件(采用_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语句是一致的。

最新文章

  1. C# winform窗体设计-数据库连接
  2. Linux:Linux 重要人物
  3. TCP拥塞控制
  4. Android 之 下拉框(Spinner)的使用
  5. 【互联网那些事儿】小度 i 耳目
  6. PHP 5.6.6 上运行 ecshop 2.7.3 不兼容问题整合
  7. Hadoop与HBase中遇到的问题
  8. 【转】AFNetworking之于https认证
  9. android 应用在启动后进行全局的的初始化操作
  10. Axure RP 实践.1
  11. 《12个有趣的C语言问答》评析2
  12. 主席树初步 HDU2665的区间第k小
  13. 必须要会的 50 个 React 面试题
  14. js 实现获取当前日期/时间/星期
  15. (二)RocketMq入门之消息发送和接收
  16. linux 配置msyql
  17. ViewPager Fragment PagerAdapter MD
  18. Laravel5.1 搭建博客 --上传文件及文件管理
  19. 中小公司的Java工程师应该如何逆袭冲进BAT?
  20. django设置打印数据库日志

热门文章

  1. StringUtils里的isEmpty和isBlank的区别
  2. Docker学习のWindows下如何访问Docker本身的虚拟机
  3. Linux 实用指令(10)-RPM和YUM
  4. java日期格式汇总
  5. thinkphp 用户注册功能
  6. DDOS 单例
  7. 小程序唤起App
  8. .NETFramework:Exception
  9. 编译报错 :The method list(String, Object[]) is ambiguous for the type BaseHibernateDao<M,PK>
  10. JS 拷贝传值和引用传值