技术文摘
SQL 中横表与纵表的转换之法
2024-12-29 02:48:36 小编
SQL 中横表与纵表的转换之法
在数据库操作中,经常会遇到需要将横表(也称为宽表)转换为纵表(也称为窄表),或者将纵表转换为横表的情况。掌握这些转换方法对于高效处理数据至关重要。
让我们来了解一下横表和纵表的概念。横表通常具有多个列来存储不同类型的数据,每行代表一个实体的完整信息。而纵表则将不同的属性值存储在不同的行中,通过额外的列来标识属性的名称。
当需要将横表转换为纵表时,我们可以使用 SQL 的 UNPIVOT 操作。例如,假设有一个横表 employee_info ,包含列 id 、 name 、 salary_2021 、 salary_2022 ,要将其转换为纵表,可以使用以下语句:
SELECT id, year, salary
FROM
(SELECT id, name, salary_2021, salary_2022
FROM employee_info) p
UNPIVOT
(salary FOR year IN (salary_2021 AS '2021', salary_2022 AS '2022')) AS unpvt;
反之,将纵表转换为横表则可以使用 PIVOT 操作。例如,有一个纵表 employee_salary ,包含列 id 、 year 、 salary ,要将其转换为横表,可以使用如下语句:
SELECT id,
MAX(CASE WHEN year = '2021' THEN salary END) AS salary_2021,
MAX(CASE WHEN year = '2022' THEN salary END) AS salary_2022
FROM employee_salary
GROUP BY id;
在实际应用中,还需要根据具体的数据结构和需求来灵活选择和调整转换方法。要注意数据的完整性和一致性,确保转换后的结果符合预期。
另外,在处理大规模数据时,性能也是需要考虑的一个重要因素。合理地创建索引、优化查询语句的结构以及选择合适的数据库引擎都有助于提高转换的效率。
掌握 SQL 中横表与纵表的转换方法是数据库操作中的一项重要技能,能够帮助我们更灵活、高效地处理和分析数据,从而为业务决策提供有力支持。
- Jenkins Pipeline 中 Shell、Python、Java 脚本的正确调用方式
- 六个不容错过的 Java 新功能
- 如何理解 Go 中的可寻址与不可寻址
- 一种比冒泡算法更简单的排序算法:看似满是 bug 的程序竟正确
- 大型 Java 项目架构演进解析
- Python 可视化打包 exe 神器,令人惊叹
- Netty 常用技法——ChannelHandler 与编解码
- 面试官提问:冒泡排序的理解、实现与应用场景
- 鸿蒙开源全场景应用之视频渲染开发
- Hi3861 驱动交流电机变频器的实现
- 子集问题需去重,你可知?
- 9 月 GitHub 热门 Java 开源项目排名
- Go 切片引发内存泄露,已入坑两次!
- 在 Linux 上借助 jconsole 监控 Java
- 开发板漂流计划:小车控制从简至繁之按键掌控