sql将行转列的有甚么方法
在SQL中,可使用以下方法将行转列:
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
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
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语句是最多见和最经常使用的方式。但根据具体的数据和需求,区分的方法可能会产生区分的效果和性能。
TOP