Sqlserver
 sql >> Baza danych >  >> RDS >> Sqlserver

Połącz wiele wyników w podzapytanie w jedną wartość oddzieloną przecinkami

Nawet to będzie służyć celowi

Przykładowe dane

declare @t table(id int, name varchar(20),somecolumn varchar(MAX))
insert into @t
    select 1,'ABC','X' union all
    select 1,'ABC','Y' union all
    select 1,'ABC','Z' union all
    select 2,'MNO','R' union all
    select 2,'MNO','S'

Zapytanie:

SELECT ID,Name,
    STUFF((SELECT ',' + CAST(T2.SomeColumn AS VARCHAR(MAX))
     FROM @T T2 WHERE T1.id = T2.id AND T1.name = T2.name
     FOR XML PATH('')),1,1,'') SOMECOLUMN
FROM @T T1
GROUP BY id,Name

Wyjście:

ID  Name    SomeColumn
1   ABC     X,Y,Z
2   MNO     R,S


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Przedstawiamy nową funkcję:Zawsze włączona grupa dostępności

  2. Klauzula WHERE lepiej wykonać przed IN i JOIN lub po

  3. Brent Ozar wyjaśnia wewnętrzną i zewnętrzną fragmentację SQL Server

  4. Jak przekazać XML z C# do procedury składowanej w SQL Server 2008?

  5. Dlaczego program SQL Server traci milisekundę?