How to concatenate multiple rows?

后端 未结 2 1217
遇见更好的自我
遇见更好的自我 2020-12-18 15:51

I have the following query which returns the salary of all employees. This work perfectly but I need to collect extra data that I will aggregate into one cell (see Result Se

相关标签:
2条回答
  • 2020-12-18 16:21

    For SQL Server 2005+, use the STUFF function and FOR XML PATH:

    WITH summary_cte AS (
       SELECT Employee.Id, SUM(Pay) as Salary
         FROM Employee
         JOIN PayCheck ON PayCheck.EmployeeId = Employee.Id
     GROUP BY Employee.Id)
    SELECT sc.id, 
           sc.salary,
           STUFF((SELECT ','+ yt.data
                    FROM your_table yt
                   WHERE yt.id = sc.id
                GROUP BY yt.data
                 FOR XML PATH(''), TYPE).value('.','VARCHAR(max)'), 1, 1, '')
      FROM summary_cte sc
    

    But you're missing details about where the data you want to turn into a comma delimited string is, and how it relates to an employee record...

    0 讨论(0)
  • 2020-12-18 16:26

    I don't have my code in front of me, or I would show you a quick example, but I would look into writing a CLR aggregate for this. Its very simple. There are some automatically created method to use, and they're just for collection (add to a List<> object or something), Merge (merging multiple lists created in multiple threads), and an output (take the list and turn it into a string - String.Join(",", list.ToArray())). Only thing to know is that there is a length limit of 8000 characters.

    0 讨论(0)
提交回复
热议问题