在mysql中,分組后將多條記錄合并成一條記錄的需求經(jīng)常會遇到。而將多個字段合并成一個長字符串就是其中一種需求。下面我們介紹一種方法來實現(xiàn)分組后字符串拼接。
假設我們有以下的數(shù)據(jù)表:
CREATE TABLE student ( id INT PRIMARY KEY, name VARCHAR(20), subject VARCHAR(20), score INT ); INSERT INTO student VALUES (1, '小明', '語文', 80), (2, '小明', '數(shù)學', 90), (3, '小明', '英語', 85), (4, '小紅', '語文', 85), (5, '小紅', '數(shù)學', 70), (6, '小紅', '英語', 90), (7, '小剛', '語文', 90), (8, '小剛', '數(shù)學', 85), (9, '小剛', '英語', 80);
我們想要將同名學生的科目和成績連成一個字符串,以逗號分隔,但保留不同種類的科目。結(jié)果應該如下所示:
+-----------+---------------------+ | name | subjects | +-----------+---------------------+ | 小明 | 語文,數(shù)學,英語 | | 小紅 | 語文,數(shù)學,英語 | | 小剛 | 語文,數(shù)學,英語 | +-----------+---------------------+
我們可以使用GROUP_CONCAT函數(shù)來實現(xiàn)這個需求。GROUP_CONCAT函數(shù)可以將一個字段的值合并成一個字符串,我們只需要指定需要合并的字段以及分隔符即可。但是,如果直接使用GROUP_CONCAT函數(shù),因為GROUP_CONCAT函數(shù)是對整個結(jié)果集進行操作的,所以同名學生的科目和成績會一起合并成一個字符串,而不是按名字分別合并。為了解決這個問題,我們需要用到子查詢。
SELECT name, GROUP_CONCAT(subject ORDER BY id) AS subjects FROM ( SELECT id, name, subject FROM student ORDER BY name, subject ) AS sub GROUP BY name;
上述代碼中,我們先按name和subject升序排序子查詢得到結(jié)果集,再在外層使用GROUP BY和GROUP_CONCAT函數(shù)來實現(xiàn)字符串拼接。ORDER BY子句可以保證結(jié)果按照id排序,在進行字符串拼接時不會出現(xiàn)亂序的情況。
需要注意的是,如果合并的字段值中包含分隔符,則需要使用SEPARATOR參數(shù)來指定分隔符,否則會出現(xiàn)不正確的結(jié)果。
以上就是在mysql中實現(xiàn)分組后字符串拼接的方法。希望這個方法對你有所幫助!
上一篇mysql單實例重置密碼
下一篇html小程序跳一跳代碼