use*_*188 1 sql sql-server-2008 sql-server-2008-r2
我需要一个关于 SELECT 的示例,其中输出是一个 ',' 分隔的字符串
例如 SELECT (... something ...) name AS output FROM name_table
给我
output
-----------------------------
'Ann', 'Tom', 'Wilson', .....
Run Code Online (Sandbox Code Playgroud)
您将如何在 SQL Server 2008 R2 中做到这一点?
谢谢!
假设您有这样的架构,
CREATE TABLE Table1
([GROUP_ID] int, [PERSON_NAME] varchar(6));
INSERT INTO Table1
([GROUP_ID], [PERSON_NAME])
VALUES
(1001, 'ALEX'),
(1002, 'MATHEW'),
(1001, 'GEORGE'),
(1002, 'THOMAS'),
(1001, 'JAMES');
Run Code Online (Sandbox Code Playgroud)
创建一个类似这样的查询来产生一个逗号分隔的值,
SELECT
GROUP_ID,
STUFF(
(SELECT ', ' + PERSON_NAME
FROM Table1
WHERE [GROUP_ID] = a.GROUP_ID
FOR XML PATH (''))
, 1, 1, '') AS NamesList
FROM Table1 AS a
GROUP BY GROUP_ID
Run Code Online (Sandbox Code Playgroud)