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;
    }

分析:

  1. 首先用func_get_args函数获取到全部参数,打包到一个索引数组中;
  2. 再用array_shift函数使参数数组中的第一个元素出列,即单独取出:字段名;
  3. parseWhereExp方法根据逻辑关系来解析上面全部参数,将结果传到字段名;
  4. 获取完整查询条件后,再次返回查询对象本身,继续调用后台连贯方法。
     该方法与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、总结:

在实际开发中,逻辑或用的不多,更多是逻辑与,但也需要掌握