ThinkPHP5数据库实例详解
/group方法
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方法也支持多字段分组,其原理也单段分组是一样的,就是分组的嵌套,因平时极少用到,感兴趣的同学,可以自己试一下,此处不再演示啦~~