Thinkphp3.2 中的where条件复杂条件下的条件组合
来源:互联网 发布:反转链表 非递归 java 编辑:程序博客网 时间:2024/05/18 01:18
组合查询的主体还是采用数组方式查询,只是加入了一些特殊的查询支持,包括字符串模式查询(_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语句是一致的。
转载自thinkphp官网手册
0 2
- Thinkphp3.2 中的where条件复杂条件下的条件组合
- where 子语句复杂条件的标准形式
- mongodb的where条件
- Thinkphp的where条件
- UPDATE语句中的WHERE条件
- SQL中的where条件提取
- 复杂的条件
- 复杂条件的查询
- on条件与where条件的区别
- on条件与where条件的区别
- on条件与where条件的区别
- on条件与where条件的区别
- on条件与where条件的区别
- on条件与where条件的区别
- on条件与where条件的区别
- where条件
- where 条件的另类写法
- Medoo Where的使用:条件
- 【CSU 1175: A Tour Around Hangzhou】+ 状压dp + dijkstra
- uvc 颜色空间
- 35 个 Java 代码性能优化总结
- [BZOJ 3240][Noi2013]矩阵游戏:逆元+递推
- 视觉SLAM中的数学基础 第二篇 四元数
- Thinkphp3.2 中的where条件复杂条件下的条件组合
- oracle 更新字段为null hibernate 报错 类型不存在 16 invalid column type 16
- JS原生代码实现鼠标移动图片随之移动效果(另加点击改变图片效果)
- 物理地址、虚拟地址、逻辑地址、线性地址、虚拟内存
- 第四届 山东省ACM SDUT 2607 Mountain Subsequences(LIS+哈希 OR 线段树 待解决)
- 异常问题:No operations allowed after connection closed.
- 身份证验证js
- ros, python初识
- Java 怎样修改文本文件内容