Ако сте на SQL Server 2017 или Azure, вижте отговора на Mathieu Renda.
Имах подобен проблем, когато се опитвах да присъединя две таблици с връзки едно към много. В SQL 2005 открих, че XML PATH
метод може да се справи с конкатенацията на редовете много лесно.
Ако има таблица, наречена STUDENTS
SubjectID StudentName
---------- -------------
1 Mary
1 John
1 Sam
2 Alaina
2 Edward
Резултатът, който очаквах беше:
SubjectID StudentName
---------- -------------
1 Mary, John, Sam
2 Alaina, Edward
Използвах следния T-SQL
:
SELECT Main.SubjectID,
LEFT(Main.Students,Len(Main.Students)-1) As "Students"
FROM
(
SELECT DISTINCT ST2.SubjectID,
(
SELECT ST1.StudentName + ',' AS [text()]
FROM dbo.Students ST1
WHERE ST1.SubjectID = ST2.SubjectID
ORDER BY ST1.SubjectID
FOR XML PATH ('')
) [Students]
FROM dbo.Students ST2
) [Main]
Можете да направите същото нещо по по-компактен начин, ако можете да свържете запетаите в началото и да използвате substring
за да пропуснете първата, за да не е необходимо да правите подзаявка:
SELECT DISTINCT ST2.SubjectID,
SUBSTRING(
(
SELECT ','+ST1.StudentName AS [text()]
FROM dbo.Students ST1
WHERE ST1.SubjectID = ST2.SubjectID
ORDER BY ST1.SubjectID
FOR XML PATH ('')
), 2, 1000) [Students]
FROM dbo.Students ST2