一、group by
对完整的数据表进行划分子表,划分的依是,指定数据列中值一样的会被划分到同一个子表中,然后使用聚合函数对子表中的数据进行计算比如获取每一生产商定价最高的产品等~
注意事项
1.可以使用单个列,多个列组合,甚至是对列的计算结果
2.分组的依据必须是可以从数据表中获得的数据
3.分组之后是针对子表数据进行操作,不会在显示单行数据等,或者说不能完整的查看单个子表的数据
4.select后面除了聚合函数处理的部分外,最好选取的列都出现在group by子句中
5.NULL 空也会被归类为一种值,所有NULL的行被分到一张子表中
6.group by 出现在where 后,order by 前面
不支持后面加聚合函数,可以再前面加,不适用并列后分组,
格式:select 列名 count(*)from 表名 group by 列名 条件;
二、条件筛选
格式:select 列名 count(*)from 表名where 条件 group by 列名having 条件 order by 列名;
三、实验
orderltems表包含每个订单的单独项目。编写一条SQL语句,返回每个订单号(order_num)的行数(作为order_lines),并按order_lines对结果排序。