SQL90 纠错3

文章提供了一个SQL查询示例,该查询从OrderItems表中统计每个订单号的出现次数。通过GROUPBY子句按order_num分组,HAVING子句过滤出订单数量大于等于3的记录,然后使用ORDERBY对订单数量和order_num进行排序。修复后的SQL查询正确地考虑了分组和排序的依据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

描述

OrderItems表含有order_num订单号

order_num

a002

a002

a002

a004

a007

【问题】将下面代码修改正确后执行

SELECT order_num, COUNT(*) AS items

FROM OrderItems

GROUP BY items

HAVING COUNT(*) >= 3

ORDER BY items, order_num;

【示例结果】

返回订单号order_num和出现的次数items

order_num

items

a002

3

【示例解析】

由于订单号a002出现了三次,所以返回3

示例1

输入:

DROP TABLE IF EXISTS `OrderItems`;

CREATE TABLE IF NOT EXISTS `OrderItems`(

order_num VARCHAR(255) NOT NULL COMMENT '商品订单号'

);

INSERT `OrderItems` VALUES ('a002'),('a002'),('a002'),('a004'),('a007');

复制

输出:

a002|3

答案

总共有2个问题:

  1. group by是指根据什么进行分组,然后进行count()计算,后面跟的名字不应该是count()函数计算后的别名

  1. order by是指根据什么进行排序,不应该是count()计算后的别名,而应该是它自己的名字。

修改后sql如下所示:

SELECT order_num, COUNT(*) AS items 
FROM OrderItems 
GROUP BY order_num 
HAVING COUNT(*) >= 3 
ORDER BY COUNT(*), order_num;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值