MySQL行轉(zhuǎn)列的方法是什么

小億
83
2023-12-25 17:43:41
欄目: 云計(jì)算

在MySQL中,可以使用以下兩種方法將行轉(zhuǎn)列:

  1. 使用CASE語(yǔ)句和聚合函數(shù):

    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;
    

    這種方法通過(guò)使用CASE語(yǔ)句將每個(gè)特定值的列放在不同的列中,并使用聚合函數(shù)(如MAX)來(lái)合并相同的行。

  2. 使用PIVOT語(yǔ)句:

    SELECT
        *
    FROM
        table_name
    PIVOT
    (
        MAX(column2)
        FOR column1 IN ('value1', 'value2', 'value3')
    ) AS p;
    

    這種方法使用PIVOT語(yǔ)句將列轉(zhuǎn)為行,并使用聚合函數(shù)(如MAX)來(lái)合并相同的行。

這兩種方法都可以將行轉(zhuǎn)為列,具體使用哪種方法取決于具體的需求和數(shù)據(jù)結(jié)構(gòu)。

0