题解 | #返回产品名称和每一项产品的总订单数#

返回产品名称和每一项产品的总订单数

http://www.nowcoder.com/practice/1c64fd9048364a58a8ffa541720359a4

这里我们用到一个ifnull函数,如果是空,输出结果是0,将Null转为0 示例结果中 soda是0,所以含有prod_name的表是主表 用到了count()函数,要按照每个pord_id计数,应该按照Prod_id进行分组

select prod_name,ifnull(orders, 0)orders
-- 这里我们用到一个ifnull函数,如果是空,输出结果是0
-- soda是 0,所以含有prod_name的表是主表
from Products p
left join
(
    select prod_id, count(*) orders
    from OrderItems
    group by prod_id
) oi
on p.prod_id = oi.prod_id
order by prod_name;
全部评论
知识点:IFNULL() 函数用于判断第一个表达式是否为 NULL,如果为 NULL 则返回第二个参数的值,如果不为 NULL 则返回第一个参数的值。
点赞 回复 分享
发布于 2022-06-05 23:59

相关推荐

头顶尖尖的程序员:我也是面了三四次才放平心态的。准备好自我介绍,不一定要背熟,可以记事本写下来读。全程控制语速,所有问题都先思考几秒,不要急着答,不要打断面试官说话。
点赞 评论 收藏
分享
代码飞升:别用口语,后端就写后端,前端就写前端,最后别光后悔
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-08 14:08
点赞 评论 收藏
分享
评论
7
5
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务