group方法

group方法

1、功能:按字段特征分组统计查询

提到分组,就必须提统计,如对统计函数陌生的同学,请复习前面课程

2、源码:/thinkphp/library/think/db/Query.php

/** * 指定group查询 * @access public * @param string $group GROUP * @return $this */ public function group($group) { $this->options['group'] = $group; return $this; }

该方法源码很简单,就是给查询对象Query中的查询选项属性option[ ]赋值,并返回查询对象自身,便于后台的链式操作。

3、参数与返回值:

  • 参数
序号 参数 说明
1 分组字段名 分组字段名必须有意义,如地区、部门,性别等,可以容纳同类数据,而工资,生日不适合于分组

group方法参数必须是字符串,不能是数组等其它类型,切记

  • 返回值:同样返回Query类查询对象,便于后台链式操作继续进行。

3、实例演示:

准备工作:

我们将tp5_staff表中的部门字段,由部门编号修改成中文名称,以便于演示

#修改表中字段dept的类型与约束条件 ALTER TABLE `tp5_staff` CHANGE dept dept VARCHAR(20) NOT NULL DEFAULT '开发部' COMMENT '部门'; #批量更新dept字段的值 UPDATE `tp5_staff` SET dept = '客服部' WHERE dept = 0; UPDATE `tp5_staff` SET dept = '开发部' WHERE dept = 1; UPDATE `tp5_staff` SET dept = '市场部' WHERE dept = 2;

  • 任务1:查询tp5_staff表中,各部门的平均工资

  • Index.php 控制器中代码如下:

 field(['dept'=>'部门','ROUND(AVG(salary),2)'=>'平均工资']) -> group('dept')->select(); //查看结果 dump($result); }
  • 查询结果如下:
array(3) { [0] => array(2) { ["部门"] => string(9) "客服部" ["平均工资"] => float(6044.25) } [1] => array(2) { ["部门"] => string(9) "市场部" ["平均工资"] => float(9431.33) } [2] => array(2) { ["部门"] => string(9) "开发部" ["平均工资"] => float(6456.43) } }

  • 生成的SQL语句:
SELECT `dept` AS `部门`,ROUND(AVG(salary),2) AS `平均工资` FROM `tp5_staff` GROUP BY dept
  • 代码分析:

    • 结果字段中不要出现与分组字段和查询结果无关的字段,例如本例中,仅出现了分组字段dept和统计函数。如果在结果字段中出现name等字段,仅表示的是满足条件的第一个记录的name,并无实际意义;
    • ROUND函数用来控制小数余入的,这里为2位;
    • AVG是计算数值型字段列的平均值,属聚合函数,仅返回单值;
    • 字段名可以使用函数,这与原生SQL写法没有区别;
    • 这里用数组方式设置了字段别名,显示更加人性人,以后我们大量用到,请熟悉它。

    4、总结:

    group方法也支持多字段分组,其原理也单段分组是一样的,就是分组的嵌套,因平时极少用到,感兴趣的同学,可以自己试一下,此处不再演示啦~~