1.原始查询表结果

2.理想查询表结果

一很牛的朋友写的sql语句
,学习啦
:
select userpwd,username=stuff((select ','+username from tuser t1 where t1.userpwd=t.userpwd for xml path('')),1,1,'')
from tuser t
group by userpwd
说明: a.stuff方法(举例说明:select stuff('abcdef', 2, 3, 'klmn'); 在第一个字符串如: abcdef 中删除从第 2 个位置(字符 b)开始的三个字符,然后在删除的起始位置插入第二个字符串,从而创建并返回一个字符串aklmnef),
b.for xml path(在SQL Server中利用 FOR XML PATH 语句能够把查询的数据生成XML数据),
c.group by(分组函数)
本文介绍了一种使用SQL实现的高级查询技巧,通过stuff和forxml path函数结合group by子句,来生成带有逗号分隔的用户名列表。这种方法可以有效地处理需要将多个字段值合并为一个字符串的场景。

1906

被折叠的 条评论
为什么被折叠?



