5

可能重复:
SQL Server:我可以用逗号将多行分隔为一列吗?

我有表 X(X_ID, X_Name) 是 1-M 表 Y(Y_ID, Y_Value)

表十:

X_ID    X_Name
----    ------
12      foo
14      foo2
16      foo3

表 Y:

X_ID    Y_Value
----    -------
12      A
12      B
14      C
14      D
14      E
16      F
16      G

如何使用 T-Sql 获得以下结果?

X_ID   X_Name   Y_Value
----   ------   ------
12     foo      A,B
14     foo2     C,D,E
16     foo3     F,G

谢谢

4

1 回答 1

15
SELECT X.X_ID, X.X_Name, Y_Values = STUFF((SELECT N',' + Y_Value FROM dbo.Y
  WHERE Y.X_ID = X.X_ID
  FOR XML PATH(''), 
  TYPE).value(N'./text()[1]', N'nvarchar(max)'), 1, 1, N'')
  FROM dbo.X;

在 SQL Server 2017 和 Azure SQL 数据库中,您可以使用新STRING_AGG()功能:

SELECT x.X_ID, x.X_Name, 
    Y_Values = STRING_AGG(Y.Y_Value,',')
  FROM dbo.X
  INNER JOIN dbo.Y
  ON X.X_ID = Y.X_ID
  GROUP BY x.X_ID, x.X_Name;

如果您不喜欢默认顺序,可以使用以下命令指定WITHIN GROUP

SELECT x.X_ID, x.X_Name, 
    Y_Values = STRING_AGG(Y.Y_Value,',') WITHIN GROUP (ORDER BY Y.Y_Value)
  FROM dbo.X
  INNER JOIN dbo.Y
  ON X.X_ID = Y.X_ID
  GROUP BY x.X_ID, x.X_Name;
于 2012-05-21T15:14:22.250 回答