学到很多丨如何取多个单独的数据再拼接起来

某宝店铺动销率与售罄率

https://www.nowcoder.com/practice/715dd44c994f45cb871afa98f1b77538?tpId=268&tags=&title=&difficulty=0&judgeStatus=0&rp=0&sourceUrl=%2Fexam%2Foj%3Fpage%3D1%26tab%3DSQL%25E7%25AF%2587%26topicId%3D268

解决的方法就是通过写多个临时表来解决如下:

多个临时表之间用逗号隔开就行了,记得带相同的主键以用来拼接

group by 1的意思是group by select后面的第1个字段

with a AS(
SELECT 
style_id,
SUM(inventory)'inventorytotal',
SUM(tag_price*inventory)'inventorymoney'
FROM product_tb
GROUP BY 1) ,

b AS(
SELECT
style_id,
SUM(sales_num)'sales_numtotal',
SUM(sales_price)'gmv'
FROM product_tb
JOIN sales_tb USING (item_id)
GROUP BY 1)


SELECT
style_id,
ROUND(sales_numtotal/(inventorytotal-sales_numtotal)*100,2)'pin_rate(%)',
ROUND(gmv/inventorymoney*100,2)'sell-through_rate(%)'
FROM a JOIN b USING(style_id)
GROUP BY 1

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-08 14:10
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-08 10:39
一个证都没 我能填什么
程序员小白条:别人有,你为什么没有,还是这个道理,社会就是比较,竞争,淘汰,你要安逸,那么就要做好淘汰的准备
点赞 评论 收藏
分享
06-25 09:33
厦门大学 Java
程序员饺子:现在日常估计没啥hc了,等到八月多估计就慢慢有了。双九✌🏻不用焦虑的
投递快手等公司7个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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