sql - 我可以用逗号将多行分隔为一列吗?

标签 sql sql-server sql-server-2008 tsql

我正在尝试将类似的内容合并到我的 SQL Server 数据库中:

[TicketID], [Person]
 T0001       Alice
 T0001       Bob
 T0002       Catherine
 T0002       Doug
 T0003       Elaine

Into this:

[TicketID], [People]
 T0001       Alice, Bob
 T0002       Catherine, Doug
 T0003       Elaine

I need to do this in both SQL Server and Oracle.

I have found the function GROUP_CONCAT for MySQL that does exactly what I need here, but MySQL is not an option here.

EDIT: Test bench:

DECLARE @Tickets TABLE (
    [TicketID] char(5) NOT NULL,
    [Person] nvarchar(15) NOT NULL
)

INSERT INTO @Tickets VALUES
    ('T0001', 'Alice'),
    ('T0001', 'Bob'),
    ('T0002', 'Catherine'),
    ('T0002', 'Doug'),
    ('T0003', 'Elaine')

SELECT * FROM @Tickets

最佳答案

以下是适用于 SQL Server 2005+ 的解决方案:

SELECT t.TicketID,
       STUFF(ISNULL((SELECT ', ' + x.Person
                FROM @Tickets x
               WHERE x.TicketID = t.TicketID
            GROUP BY x.Person
             FOR XML PATH (''), TYPE).value('.','VARCHAR(max)'), ''), 1, 2, '') [No Preceeding Comma],
       ISNULL((SELECT ', ' + x.Person
                FROM @Tickets x
               WHERE x.TicketID = t.TicketID
            GROUP BY x.Person
             FOR XML PATH (''), TYPE).value('.','VARCHAR(max)'), '') [Preceeding Comma If Not Empty]
  FROM @Tickets t
GROUP BY t.TicketID

引用:

关于sql - 我可以用逗号将多行分隔为一列吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2046037/

相关文章:

java - Hibernate Criteria 查询 : getting a list of objects with a m. .n 子表没有特定属性的关系

sql-server - 带支票|忽略现有数据检查强制的 NOCHECK 选项

sql - 使用全文搜索查找完全匹配

sql - 如何从 MS SQL Server 2012 中的不同表中减去连续的行?

sql - 如何一次加载特定行 100

sql-server - SQL 服务器 2008 : Varchar to Datetime conversion

mysql - 选择薪水高于其部门平均水平的每位员工

mysql - SQL - "merge"3 个带有 JOIN 的表

C#:通过ODBC读取数据算术溢出

sql-server - 使用 SQL Azure DB 将 Umbraco 8.1.1 部署到 Azure : Boot Failed