web-dev-qa-db-fra.com

ListAGG dans SQLSERVER

J'essaye d'agréger un champ 'STRING' dans SQLServer. Je voudrais trouver la même fonction LISTAGG comme dans Oracle.

Savez-vous comment faire la même fonction ou une autre méthode?

Par exemple,

Field A | Field B
1       |  A
1       |  B
2       |  A

Et j'aimerais que le résultat de cette requête soit 

1 | AB
2 | A
55
user1557642

Dans SQL Server, vous pouvez utiliser FOR XML PATH pour obtenir le résultat:

select distinct t1.FieldA,
  STUFF((SELECT distinct '' + t2.FieldB
         from yourtable t2
         where t1.FieldA = t2.FieldA
            FOR XML PATH(''), TYPE
            ).value('.', 'NVARCHAR(MAX)') 
        ,1,0,'') data
from yourtable t1;

Voir SQL Fiddle avec Demo

53
Taryn

MySQL

SELECT FieldA
     , GROUP_CONCAT(FieldB ORDER BY FieldB SEPARATOR ',') AS FieldBs
  FROM TableName
 GROUP BY FieldA
 ORDER BY FieldA;

Oracle et DB2

SELECT FieldA
     , LISTAGG(FieldB, ',') WITHIN GROUP (ORDER BY FieldB) AS FieldBs
  FROM TableName
 GROUP BY FieldA
 ORDER BY FieldA;

PostgreSQL

SELECT FieldA
     , STRING_AGG(FieldB, ',' ORDER BY FieldB) AS FieldBs
  FROM TableName
 GROUP BY FieldA
 ORDER BY FieldA;

Serveur SQL

SQL Server ≥ 2017 & SQL Azure

SELECT FieldA
     , STRING_AGG(FieldB, ',') WITHIN GROUP (ORDER BY FieldB) AS FieldBs
  FROM TableName
 GROUP BY FieldA
 ORDER BY FieldA;

SQL Server ≤ 2016 (CTE inclus pour encourager le principe de DRY )

  WITH CTE_TableName AS (
       SELECT FieldA, FieldB
         FROM TableName)
SELECT t0.FieldA
     , STUFF((
       SELECT ',' + t1.FieldB
         FROM CTE_TableName t1
        WHERE t1.FieldA = t0.FieldA
        ORDER BY t1.FieldB
          FOR XML PATH('')), 1, LEN(','), '') AS FieldBs
  FROM CTE_TableName t0
 GROUP BY t0.FieldA
 ORDER BY FieldA;

SQLite

La commande nécessite un CTE ou une sous-requête

  WITH CTE_TableName AS (
       SELECT FieldA, FieldB
         FROM TableName
        ORDER BY FieldA, FieldB)
SELECT FieldA
     , GROUP_CONCAT(FieldB, ',') AS FieldBs
  FROM CTE_TableName
 GROUP BY FieldA
 ORDER BY FieldA;

Sans commande

SELECT FieldA
     , GROUP_CONCAT(FieldB, ',') AS FieldBs
  FROM TableName
 GROUP BY FieldA
 ORDER BY FieldA;
102
Manas Kumar

Dans SQL Server 2017 STRING_AGG est ajouté:

SELECT t.name,STRING_AGG (c.name, ',') AS csv
FROM sys.tables t
JOIN sys.columns c on t.object_id = c.object_id
GROUP BY t.name
ORDER BY 1

Aussi, STRING_SPLIT est utile dans le cas contraire et disponible dans SQL Server 2016

19
vldmrrdjcc

Cela pourrait être utile à quelqu'un aussi ..

c.-à-d. à des fins d'analyste et de profilage de données.

Avant l'existence de la fonction SQL * Server 2017 String_agg ..

(c’est-à-dire qu’il ne retourne qu’une rangée ..)

select distinct
SUBSTRING (
stuff(( select distinct ',' + [FieldB] from tablename order by 1 FOR XML PATH(''), TYPE).value('.', 'NVARCHAR(MAX)') 
,1,0,'' ) 
,2,9999)
from 
    tablename 

par exemple. retourne les valeurs séparées par des virgules A, B

0
Allan F