题解 | #返回每个顾客不同订单的总金额#

返回每个顾客不同订单的总金额

https://www.nowcoder.com/practice/ce313253a81c4947b20e801cd4da7894

select od.cust_id, 
sum(ot.item_price * ot.quantity) AS total_order
from Orders AS od
JOIN OrderItems AS ot
ON od.order_num = ot.order_num
GROUP BY od.cust_id
ORDER BY total_order DESC

cust1为例的模拟执行过程如下:

  1. 外层查询选择Orders表中的cust_id,即cust1
  2. 子查询中,过滤条件为a.order_num = b.order_num,对应Orders表中order_numOrderItems表中order_num的关联。
  3. 对于OrderItems表中order_numa0002的两条记录,计算每条记录的item_price * quantity,然后对这两个计算结果进行求和,得到total_ordered。 第一条记录:1 * 1100 = 1100第二条记录:1 * 200 = 200总和:1100 + 200 = 1300
  4. 将计算得到的total_ordered值作为一列返回给外层查询,并成为结果集的一部分。
  5. 最后,根据ORDER BY total_ordered DESC的要求,按照total_ordered值从大到小排序。

根据这个过程,对于cust_idcust1,最终的查询结果应该是:

cust1

1300

这个逻辑同样适用于其他cust_id,具体的order_numtotal_ordered的值会根据数据进行相应的计算。整个查询过程就是对每个cust_id计算其相应的total_ordered,并按照total_ordered值进行排序。

内连接

select od.cust_id, 
sum(ot.item_price * ot.quantity) AS total_order
from Orders AS od
JOIN OrderItems AS ot
ON od.order_num = ot.order_num
GROUP BY od.cust_id
ORDER BY total_order DESC

题目

我们需要一个顾客 ID 列表,其中包含他们已订购的总金额。

OrderItems表代表订单信息,OrderItems表有订单号:order_num和商品售出价格:item_price、商品数量:quantity。

order_num

item_price

quantity

a0001

10

105

a0002

1

1100

a0002

1

200

a0013

2

1121

a0003

5

10

a0003

1

19

a0003

7

5

Orders表订单号:

order_num

顾客id:

cust_id

order_num

cust_id

a0001

cust

10

a0002

cust

1

a0003

cust

1

a0013

cust

2

【问题】

编写 SQL语句,返回顾客 ID(Orders 表中的 cust_id),并使用子查询返回total_ordered 以便返回每个顾客的订单总数,将结果按金额从大到小排序。

提示:你之前已经使用 SUM()计算订单总数。

【示例结果】返回顾客id cust_id和total_order下单总额

cust_id

total_ordered

cust2

2242

cust

1

1300

cust

10

1050

cust

2

104

【示例解析】cust2在Orders里面的订单a0013,a0013的售出价格是2售出数量是1121,总额是2242,最后返回cust2的支付总额是2242。

全部评论

相关推荐

1.第一种人呢以92和计算机强双非(四邮四电)偏多,这种人呢,喜欢把自己的学校称为“大专”,极力在交流时贬低自己的学历,放大自己学历的缺点(如牛客经典贴,双非秋招oc美团,点开发现是985硕士🤣🤣🤣),说的自己学校好像比双非认可度还低,好像这样才能突出自己多么牛逼,克服了多少困难,技术有多强,但你要是说想双非考研去他们学校,他们又要狠狠打压你,告诉考他们学校多难了🤣🤣🤣。从92到大厂明明是证明自己一直优秀的一条路,你不走,你非要故意恶心自己也恶心别人,何必呢?2.第二种人以像我一样的双非同学偏多,大多学历比较低,可能又带有中大厂实习。他们会在你交流的时候,十分刻意的强调自己是弱双非或者学院本,再不经意透露自己在某某大厂实习。等着群聊里响起“原来是xx(大厂名字)✌🏻啊,给你跪了😭”,他们便心满意足了。不用反驳,因为我之前也是这种人,现在也有这种倾向😆😆😆。3.第三种人更是神人,跟这种人交流时,你会觉得对方已经被美国植入芯片控制了,张嘴闭嘴只有膜膜膜,羡慕羡慕羡慕。上到拿到大厂offer,下到喝一杯奶茶,他们都说羡慕。不知道他们的生活过得有多么悲惨,连喝杯饮料都到了羡慕的地步🤣🤣🤣。天天就是在群里面互相吹捧,互相羡慕,不知道交流起来有什么意思。4.第四种人则是第一种人的对立面,我有时候觉得是第四种人太多才会导致第一种人的出现。这种人天生带着对92的恨。仿佛学计算机没有拿到offer全是92导致的。他们是小说里被陷害的白莲花女主,92则是夺走他们人生的恶毒女配。在他们的眼中,他们的技术要比92好一百倍,但是所有企业都识别不了他们这匹千里马。实际自己从来没想过,在ai与辅导课程普及的当日,所谓的计算机,早已经没有了任何的技术壁垒,否则也不会有那么人转码了😂。这是那天回家路上发抖音的,讨论不少,有赞同有不赞同的,其实有时候也在想自己言论是否偏激。今天遇到朋友问我好久没更新牛客了,就搬了上去。其实很简单,加了交流群之后,发现交流的质量参差不齐,有些实在言之无物,想了想自己也会有这样的问题。自己也在建交流群,希望能避免这样的现象吧
wu970:交流群不就是一群人互相装逼和加装谦虚吗
如何排解工作中的焦虑
点赞 评论 收藏
分享
哞客37422655...:你猜为什么福利这么好还得一直追着你问
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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