SELECT GROUP_CONCAT(CASE WHEN `column_name` = 'a' THEN `column_value` END) AS 'a', GROUP_CONCAT(CASE WHEN `column_name` = 'b' THEN `column_value` END) AS 'b', GROUP_CONCAT(CASE WHEN `column_name` = 'c' THEN `column_value` END) AS 'c' FROM `your_table` GROUP BY `id`
上述语句中,大家使用了一个叫做GROUP_CONCAT的MySQL内置函数,它可以将一个组内的多个值连接起来。
在这个语句中,大家将需要转换的列名通过CASE WHEN语句进行判断。如果该列名是大家需要的某一个,则将其对应的数据值取出来,并使用GROUP_CONCAT函数进行连接。最终,大家可以按照某个关键字进行分组得到大家需要的结果。
需要注意的是,由于GROUP_CONCAT函数的默认限制,如果要连接的值超过了默认值,需要进行一些配置才能正常使用该函数。