【大数据面试题】38 说说 Hive 怎么行转列
创始人
2024-11-21 18:37:09

一步一个脚印,一天一道大数据面试题

博主希望能够得到大家的点赞收藏支持!非常感谢
点赞,收藏是情分,不点是本分。祝你身体健康,事事顺心!

行转列

假设我们有一张名为 sales_data 的表,其中包含 product_id(产品 ID)、category(类别)和 sales_amount(销售金额)这几列的数据。

步骤:

  1. group by id
  2. 聚合函数sum/max/min,里面套一个 if / case when
  3. as 列名

样例数据:

-- 样例 SQL SELECT * FROM students; +-----------+------------+-------------+ | stu_id    | subject    | score       | +-----------+------------+-------------+ | 1         | Chinese    | 80          | | 1         | Math       | 70          | | 1         | English    | 75          | | 2         | Chinese    | 77          | | 2         | Math       | 60          | | 2         | English    | 80          | +-----------+------------+-------------+ 

开始行转列:

SELECT stu_id,        SUM(IF(subject = 'Chinese', score, 0) AS chinese_score),        SUM(IF(subject = 'Math', score, 0) AS math_score),        SUM(IF(subject = 'English', score, 0) AS english_score) FROM students GROUP BY stu_id;  +-----------+--------------+-------------+---------------+ | stu_id    | chinese_score| math_score  | english_score | +-----------+--------------+-------------+---------------+ | 1         | 80           | 70          | 75            | | 2         | 77           | 60          | 80            | +-----------+--------------+-------------+---------------+ 

我是近未来,祝你变得更强!

相关内容

热门资讯

国际最新研究:蝴蝶蜜蜂等传粉者... 北京5月7日电 (记者 孙自法)国际学术期刊《自然》最新发表一篇生态学论文称,一项研究显示,在尼泊尔...
Anthropic发布10个金... 2026年5月5日晚,Anthropic的一次发布,让华尔街的很多人没睡好觉。 这家AI公司一口气推...
原创 4... ## 933图片插入失败: 'NoneType' object has no attribute '...
三星造工厂机器人、Meta做家... 据韩国中央日报5月7号报道,全球人工智能竞争正加速向物理AI领域延伸,人形机器人成为产业霸权新焦点。...
超22万颗GPU!SpaceX... 来源:环球网 【环球网科技综合报道】5月7日消息,据《福布斯》报道,美国太空探索技术公司(Spac...