在线客服
扫描二维码
下载博学谷APP
扫描二维码
关注博学谷微信公众号
分组和聚合函数的组合怎么使用?代码怎么写?分组函数group by,聚合函数COUNT、MAX、MIN、AVG、SUM。分组聚合函数也可称之为多行函数,输入多个行构成得一个行集,将查询对象按肯定条件分组,然后对每一个组进行聚合分析。

在实际SQ应用中需要进行分组聚合,将查询对象按肯定条件分组然后对每一个组进行聚合分析。如我们常见的一些分组运算需求:求某个部门的薪资总和,薪资平均值,薪资最大值等;
分组聚合函数称之为多行函数,输入多个行构成得一个行集(这个行集可以是一张表的全部行,也可以是依据某个维度进行分组后的某一组行)而输出都是一个值。
学习目标:能够写出分组和聚合函数组合使用的SQL语句
一、数据准备
-- 创建 "京东" 数据库
create database jing_dong charset=utf8;
-- 使用 "京东" 数据库
use jing_dong;
-- 创建一个商品goods数据表
create table goods(
id int unsigned primary key auto_increment not null,
name varchar(150) not null,
cate_name varchar(40) not null,
brand_name varchar(40) not null,
price decimal(10,3) not null default 0,
is_show bit not null default 1,
is_saleoff bit not null default 0
);
-- 向goods表中插入数据
insert into goods values(0,'r510vc 15.6英寸笔记本','笔记本','华硕','3399',default,default);
insert into goods values(0,'y400n 14.0英寸笔记本电脑','笔记本','联想','4999',default,default);
insert into goods values(0,'g150th 15.6英寸游戏本','游戏本','雷神','8499',default,default);
insert into goods values(0,'x550cc 15.6英寸笔记本','笔记本','华硕','2799',default,default);
insert into goods values(0,'x240 超极本','超级本','联想','4880',default,default);
insert into goods values(0,'u330p 13.3英寸超极本','超级本','联想','4299',default,default);
insert into goods values(0,'svp13226scb 触控超极本','超级本','索尼','7999',default,default);
insert into goods values(0,'ipad mini 7.9英寸平板电脑','平板电脑','苹果','1998',default,default);
insert into goods values(0,'ipad air 9.7英寸平板电脑','平板电脑','苹果','3388',default,default);
insert into goods values(0,'ipad mini 配备 retina 显示屏','平板电脑','苹果','2788',default,default);
insert into goods values(0,'ideacentre c340 20英寸一体电脑 ','台式机','联想','3499',default,default);
insert into goods values(0,'vostro 3800-r1206 台式电脑','台式机','戴尔','2899',default,default);
insert into goods values(0,'imac me086ch/a 21.5英寸一体电脑','台式机','苹果','9188',default,default);
insert into goods values(0,'at7-7414lp 台式电脑 linux )','台式机','宏碁','3699',default,default);
insert into goods values(0,'z220sff f4f06pa工作站','服务器/工作站','惠普','4288',default,default);
insert into goods values(0,'poweredge ii服务器','服务器/工作站','戴尔','5388',default,default);
insert into goods values(0,'mac pro专业级台式电脑','服务器/工作站','苹果','28888',default,default);
insert into goods values(0,'hmz-t3w 头戴显示设备','笔记本配件','索尼','6999',default,default);
insert into goods values(0,'商务双肩背包','笔记本配件','索尼','99',default,default);
insert into goods values(0,'x3250 m4机架式服务器','服务器/工作站','ibm','6888',default,default);
insert into goods values(0,'商务双肩背包','笔记本配件','索尼','99',default,default);
表结构说明:
id 表示主键 自增
name 表示商品名称
cate_name 表示分类名称
brand_name 表示品牌名称
price 表示价格
is_show 表示是否显示
is_saleoff 表示是否售完
二、SQL语句演练
1、查询类型cate_name为 '超极本' 的商品名称、价格
select name,price from goods where cate_name = '超级本';
2、显示商品的分类
select cate_name from goods group by cate_name;
3、求所有电脑产品的平均价格,并且保留两位小数
select round(avg(price),2) as avg_price from goods;
4、显示每种商品的平均价格
select cate_name,avg(price) from goods group by cate_name;
5、查询每种类型的商品中 最贵、最便宜、平均价、数量
select cate_name,max(price),min(price),avg(price),count(*)
from goods group by cate_name;
6、查询所有价格大于平均价格的商品,并且按价格降序排序
select id,name,price from goods
where price > (select round(avg(price),2) as avg_price from goods)
order by price desc; — 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
学习Python基础知识难不难?零基础可以学吗?
学习Python基础知识难不难?零基础可以学吗?Python是公认的新手友好语言,如果零基础的小伙伴想学习编程语言,那么Python绝对是最好的选择。至于学习难度,就需要看个人的学习能力了。对于零基础的学习者来说,最重要的就是有一个合理的学习规划和资深老师的引导。本文将给大家介绍博学谷的零基础Python课程,即使是零基础也可以轻松入门Python。
8032
2019-10-29 15:01:04
Python工程师培训要多久?
Python作为目前备受初学者青睐的编程语言,学习的难度与其他语言相比,还是比较容易入门的。当然,一些零基础的初学者想要一两个月就能速成Python,还是不太可能的。尤其是想在学完之后应聘相关岗位,就算是最快的学习方式参加培训也不可能那么快就能学完就业。那么可能有人会问了,Python工程师培训要多久呢?
7117
2020-03-11 23:55:50
怎么开始学习Python开发?0基础入门Python
怎么开始学习Python开发这个问题,在各大社群网站上常常看到想要转行IT,或者是想学习编程但不知如何开始的网友。对于新手来说,掌握Python基础是关键,了解HTML,CSS,JavaScript,Ajax,jQuery,React,SQL,服务器脚本等知识。
6351
2020-05-15 17:41:38
Python IDE和解释器的区别是什么?
经常会有刚刚入门Python的初学者把Python IDE与Python解释器弄混,其实它们是有本质区别的,有些人还会误认为配置Python环境就是配置IDE工具。那么,Python IDE和解释器的区别是什么呢?下面小编就带大家好好认识一下Python IDE和解释器。
9661
2020-08-12 16:31:12
Jquery如何获取和设置元素内容?代码怎么写?
Jquery如何获取和设置元素内容?代码怎么写?jQuery 具有可操作 HTML 元素和属性的方法,其中jQuery 非常重要的部分就是操作DOM,获得- text()、html() 以及 val()内容。
4871
2022-01-05 09:32:48
