【大数据面试题】38 说说 Hive 怎么行转列

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

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

行转列

假设我们有一张名为 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            |
+-----------+--------------+-------------+---------------+

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

相关推荐

  1. 数据面试38 说说 Hive 怎么

    2024-07-21 21:28:04       16 阅读
  2. Hive数据仓库

    2024-07-21 21:28:04       45 阅读
  3. 数据开发(Hive面试

    2024-07-21 21:28:04       37 阅读
  4. 数据开发(Hive面试-卷一)

    2024-07-21 21:28:04       41 阅读
  5. 数据开发(Hive面试-卷二)

    2024-07-21 21:28:04       39 阅读
  6. 数据开发(Hive面试-卷三)

    2024-07-21 21:28:04       41 阅读
  7. 利用pandas进行数据转行

    2024-07-21 21:28:04       32 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-21 21:28:04       52 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-21 21:28:04       54 阅读
  3. 在Django里面运行非项目文件

    2024-07-21 21:28:04       45 阅读
  4. Python语言-面向对象

    2024-07-21 21:28:04       55 阅读

热门阅读

  1. 10步职业进阶:全新霍兰德自我提升计划

    2024-07-21 21:28:04       19 阅读
  2. Nginx系列-4 proxy_pass使用和路径拼接问题

    2024-07-21 21:28:04       14 阅读
  3. ASPICE在汽车软件开发中的作用

    2024-07-21 21:28:04       15 阅读
  4. C++ STL partion_point用法

    2024-07-21 21:28:04       15 阅读
  5. 【深度学习】sdxl的Lora训练技巧

    2024-07-21 21:28:04       18 阅读
  6. 理解Cookie、Session和Token

    2024-07-21 21:28:04       16 阅读
  7. 第四节shell条件测试(5)

    2024-07-21 21:28:04       18 阅读
  8. Python内存泄漏排查

    2024-07-21 21:28:04       16 阅读
  9. 【瓴岳科技】历史面试题

    2024-07-21 21:28:04       18 阅读