我正在研究一个应该给我结果的查询:
|--Name--|--Surname--|--Language--|--Date-- | | James | Hetfield | en,gb,fr | 2011-01-01| | Lars | Ulrich | gb,fr,ca | 2011-01-01|
但我的选择获取了一组行:
| James | Hetfield | en | 2011-01-01| | James | Hetfield | gb | 2011-01-01| | James | Hetfield | fr | 2011-01-01| | Lars | Ulrich | gb | 2011-01-01| | Lars | Ulrich | fr | 2011-01-01| | Lars | Ulrich | ca | 2011-01-01|
您建议使用哪种最佳方法将结果集转换为“动态”分组列中的逗号分隔值?我发现CROSS APPLY可以完成这项工作,但人们说这种方法很耗费。另外,DB有大量的数据。
提前致谢, 问候, 阿德里安
答案 0 :(得分:8)
这是最好的连接方法,它不会像其他XML方法那样扩展特殊字符:
--Concatenation with FOR XML & eliminating control/encoded char expansion "& < >"
set nocount on;
declare @YourTable table (RowID int, HeaderValue int, ChildValue varchar(5))
insert into @YourTable VALUES (1,1,'CCC')
insert into @YourTable VALUES (2,2,'B<&>B')
insert into @YourTable VALUES (3,2,'AAA')
insert into @YourTable VALUES (4,3,'<br>')
insert into @YourTable VALUES (5,3,'A & Z')
set nocount off
SELECT
t1.HeaderValue
,STUFF(
(SELECT
', ' + t2.ChildValue
FROM @YourTable t2
WHERE t1.HeaderValue=t2.HeaderValue
ORDER BY t2.ChildValue
FOR XML PATH(''), TYPE
).value('.','varchar(max)')
,1,2, ''
) AS ChildValues
FROM @YourTable t1
GROUP BY t1.HeaderValue
输出:
HeaderValue ChildValues
----------- ---------------
1 CCC
2 AAA, B<&>B
3 <br>, A & Z
(3 row(s) affected)
答案 1 :(得分:2)
如果您的SQL版本支持使用FOR XML
select n.[name],CONVERT(VARCHAR(MAX),(SELECT *
FROM (
SELECT l.[lang] + ' , ' AS '*'
FROM tblLang l
WHERE l.[name]=n.[name]
) x
FOR XML PATH (''), TYPE
)) AS [Language]
from tblName n
这假设简单的表格如
tblName
-------
name VARCHAR
tblLang
-------
lang VARCHAR
name VARCHAR
它还会添加一个尾随,
:(