阅读量:1
在SQL中,可以使用以下方法将行转列:
- 使用CASE语句:
使用多个CASE语句,每个语句对应一个要转置的列,并使用不同的条件来选择要转置的行。然后使用聚合函数(如SUM、MAX、MIN)来对转置的列进行汇总。
示例:
SELECT MAX(CASE WHEN condition_1 THEN value_1 END) AS column_1, MAX(CASE WHEN condition_2 THEN value_2 END) AS column_2, ... FROM table_name
- 使用PIVOT语句:
PIVOT语句是一种用于执行行列转换的特殊语法。它需要指定要转置的列和要进行聚合的列,并且可以选择使用哪种聚合函数。
示例:
SELECT * FROM ( SELECT column_1, column_2, ... FROM table_name ) AS source_table PIVOT ( aggregate_function(column_to_aggregate) FOR column_to_pivot IN (list_of_pivot_values) ) AS pivot_table
- 使用UNION ALL语句:
将每个要转置的列子查询,并使用UNION ALL将它们连接起来。
示例:
SELECT 'column_1' AS column_name, column_1 AS column_value FROM table_name UNION ALL SELECT 'column_2' AS column_name, column_2 AS column_value FROM table_name ...
这些方法中,使用CASE语句和PIVOT语句是最常见和最常用的方式。但根据具体的数据和需求,不同的方法可能会产生不同的效果和性能。