在MySQL中,可以使用以下兩種方法將行轉列:
使用CASE語句和聚合函數:
SELECT
MAX(CASE WHEN column1 = 'value1' THEN column2 END) AS value1,
MAX(CASE WHEN column1 = 'value2' THEN column2 END) AS value2,
MAX(CASE WHEN column1 = 'value3' THEN column2 END) AS value3
FROM
table_name
GROUP BY
column3;
這種方法通過使用CASE語句將每個特定值的列放在不同的列中,并使用聚合函數(如MAX)來合并相同的行。
使用PIVOT語句:
SELECT
*
FROM
table_name
PIVOT
(
MAX(column2)
FOR column1 IN ('value1', 'value2', 'value3')
) AS p;
這種方法使用PIVOT語句將列轉為行,并使用聚合函數(如MAX)來合并相同的行。
這兩種方法都可以將行轉為列,具體使用哪種方法取決于具體的需求和數據結構。