ThinkPHP5数据库实例详解
/ whereOr方法
whereOr方法
whereOr 方法
1. 功能:生成查询条件(OR)
whereOr与where方法用法基本相同,区别仅在于生成的查询之间的逻辑关系不同!
2. 源码:
1、/thinkphp/library/think/db/Query.php
- whereOr 方法源码:
/** * 指定OR查询条件 * @access public * @param mixed $field 查询字段 * @param mixed $op 查询表达式 * @param mixed $condition 查询条件 * @return $this */ public function whereOr($field, $op = null, $condition = null) { $param = func_get_args(); array_shift($param); $this->parseWhereExp('OR', $field, $op, $condition, $param); return $this; }
分析:
- 首先用func_get_args函数获取到全部参数,打包到一个索引数组中;
- 再用array_shift函数使参数数组中的第一个元素出列,即单独取出:字段名;
- parseWhereExp方法根据逻辑关系来解析上面全部参数,将结果传到字段名;
- 获取完整查询条件后,再次返回查询对象本身,继续调用后台连贯方法。
该方法与where方法源码基本一致,区别仅在查询条件解析函数参数‘OR’上
3、参数与返回值
- 方法原型:
/** * 指定OR查询条件 * @access public * @param mixed $field 查询字段 * @param mixed $op 查询表达式 * @param mixed $condition 查询条件 * @return $this */ public function whereOr($field, $op = null, $condition = null)
描述:
whereOr( 字段名,表达式,查询条件);
参数
序号 | 参数 | 说明 |
---|---|---|
1 | $field:查询字段 | 必须是表中存在的字段,支持别名 |
2 | $op:查询表达式 | 算术、逻辑、比较运算符 |
3 | $condition:查询条件 | 字符串、数值、数组等 |
- 返回值:与其它连贯方法一样,返回查询对象本身(Query对象)
4、适合环境:可连续调用多次,多条件之间为逻辑与(OR)关系
5、实例:
以最简单的字符串方式来举例,更高级用法下节课讲
- 先看一下当前tp5_staff表中数据情:
任务1 :查询表中dept=1的员工信息,用whereOr方法
- Index.php 控制器代码:
<?php namespace app\index\controller; //导入数据库类 use think\Db; class Index { public function index(){ //查询 dept(部门)等于 1 的员工信息 $result = Db::table('tp5_staff') // 设置数据表 -> field('id,name,dept') // 设置结果集中允许显示的字段 -> whereOr('dept = 1') // 设置查询条件 -> select(); // 获取结果集 //查看结果 dump($result); } }
- 查询结果如下:
array(4) { [0] => array(3) { ["id"] => int(1011) ["name"] => string(9) "李云龙" ["dept"] => int(1) } [1] => array(3) { ["id"] => int(1024) ["name"] => string(9) "鲁大师" ["dept"] => int(1) } [2] => array(3) { ["id"] => int(1027) ["name"] => string(9) "程序员" ["dept"] => int(1) } [3] => array(3) { ["id"] => int(1028) ["name"] => string(6) "方方" ["dept"] => int(1) } }
分析:当只有一个条件时,where和whereOr是没有区别的,返回结果一样。这也符合实际,因为AND,OR必须是一个以上条件之间的关系
任务2:查询表中dept=1 或者 sex =1 的员工信息
这比上例多了一个条件:“逻辑或”(OR)关系,记录中,只要满足这二个条件中任何一个,都会出现在结果集中
- Index.php 控制器代码:
<?php namespace app\index\controller; //导入数据库类 use think\Db; class Index { public function index(){ //查询 dept(部门)等于 1 的员工信息 $result = Db::table('tp5_staff') // 设置数据表 -> field('id,name,dept') // 设置结果集中允许显示的字段 -> where('dept = 1') // 设置查询条件dept =1 -> whereOr('sex = 1') // 设置查询条件 sex = 1 逻辑OR关系 -> select(); // 获取结果集 //查看结果 dump($result); } }
- 查询结果如下:
array(7) { [0] => array(3) { ["id"] => int(1009) ["name"] => string(9) "老顽童" ["dept"] => int(2) } [1] => array(3) { ["id"] => int(1010) ["name"] => string(9) "欧阳峰" ["dept"] => int(2) } [2] => array(3) { ["id"] => int(1011) ["name"] => string(9) "李云龙" ["dept"] => int(1) } [3] => array(3) { ["id"] => int(1012) ["name"] => string(9) "楚云飞" ["dept"] => int(3) } [4] => array(3) { ["id"] => int(1024) ["name"] => string(9) "鲁大师" ["dept"] => int(1) } [5] => array(3) { ["id"] => int(1027) ["name"] => string(9) "程序员" ["dept"] => int(1) } [6] => array(3) { ["id"] => int(1028) ["name"] => string(6) "方方" ["dept"] => int(1) } }
对于逻辑或关系,第一个用where和whereOr是没有区别的,如:
-> where('dept = 1') // 设置查询条件dept =1 -> whereOr('sex = 1') // 设置查询条件 sex = 1 逻辑OR关系 // 换种写法: -> whereOr('dept = 1') // 设置查询条件dept =1 -> whereOr('sex = 1') // 设置查询条件 sex = 1 逻辑OR关系
- 生成SQL:
SELECT `id`,`name`,`dept` FROM `tp5_staff` WHERE ( dept = 1 ) OR ( sex = 1 )
- 查看表中数据:
6、总结:
在实际开发中,逻辑或用的不多,更多是逻辑与,但也需要掌握