Home >Database >Mysql Tutorial >How to Concatenate Multiple Labels into a Single Row Based on ID?

How to Concatenate Multiple Labels into a Single Row Based on ID?

Susan Sarandon
Susan SarandonOriginal
2024-12-30 21:52:10816browse

How to Concatenate Multiple Labels into a Single Row Based on ID?

Concatenating Values Based on ID

This question seeks to transform a table with multiple rows per ID and a single 'Label' column into a table with one row per ID and a concatenated 'Label' column. Each label should be separated by commas.

The provided data consists of the following observations:

Response_ID Label
12147 It was not clear
12458 Did not Undersstand
12458 Was not resolved
12458 Did not communicate
12586 Spoke too fast
12587 Too slow

The desired output is:

Response_ID Label
12147 It was not clear
12458 Did not Undersstand,Was not resolved,Did not communicate
12586 Spoke too fast
12587 Too Slow

To achieve this transformation, the following code snippet can be used:

declare @T table(Response_ID int, Label varchar(50))
insert into @T values
(12147,          'It was not clear'),
(12458,          'Did not Undersstand'),
(12458,          'Was not resolved'),
(12458,          'Did not communicate'),
(12586,          'Spoke too fast'),
(12587,          'Too slow')

select T1.Response_ID,
       stuff((select ','+T2.Label
              from @T as T2
              where T1.Response_ID = T2.Response_ID
              for xml path(''), type).value('.', 'varchar(max)'), 1, 1, '') as Label
from @T as T1
group by T1.Response_ID

The subquery in the 'stuff' function uses concatenation via the ' ' operator and XML methods to handle the combination of labels. The 'type' parameter's 'value' function converts the XML output into a varchar(max) type to ensure proper display of concatenated results.

Please note that without an order by statement in the subquery, the order of concatenated strings cannot be guaranteed.

The above is the detailed content of How to Concatenate Multiple Labels into a Single Row Based on ID?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn