mysql的group by和having结合使用案例

题目:

要求:

只能使用一个select,不能使用子查询,必须使用group by 和 having

方法:

步骤1:

#创建表stu,其他字段这里用不到
create table stu(
    name varchar(10) not null default '',
    subject varchar(10) not null default '',
    score tinyint not null default 0
);
insert into stu 
values
('张三','数学',90),
('张三','语文',50),
('张三','地理',40),
('李四','语文',55),
('李四','政治',45),
('王五','政治',30);

步骤2:

#每个人每科是否及格
select name,score < 60 from stu;

运行结果如下:

步骤3:

#每个人不及格科目数量
select name, sum(score < 60) from stu group by name;

运行结果:

步骤4:

#每个人不及格科目数量和平均分
select name,sum(score < 60),avg(score) from stu group by name;

运行结果:

步骤5:

#不及格科目数量大于等于2 的学生的平均分
select name,sum(score < 60) as gk,avg(score) as average from stu group by name having gk >= 2

:要把表的当作变量使用

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值