sql

sql将行转列的方法有哪些

小亿
258
2023-10-12 17:23:19
栏目: 云计算

在SQL中,可以使用以下方法将行转列:

  1. 使用CASE语句:
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
  1. 使用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
  1. 使用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语句是最常见和最常用的方式。但根据具体的数据和需求,不同的方法可能会产生不同的效果和性能。

0
看了该问题的人还看了