Sql Server:多行合并成一行,并做分组统计的两个方法
更新时间:2013年02月21日 09:59:24 作者:
Sql Server:多行合并成一行,并做分组统计的两个方法,需要的朋友可以参考一下
复制代码 代码如下:
--创建 test 表 ,插入数据
CREATE TABLE test(code varchar(50), [values] varchar(10),[count] int)
INSERT test SELECT '001', 'aa',1
UNION ALL SELECT '001', 'bb',2
UNION ALL SELECT '002', 'aaa',4
UNION ALL SELECT '002', 'bbb',5
UNION ALL SELECT '002', 'ccc',3;
--方法一
--将多行合并成一行,并做分组统计
SELECT code,
[values] =
stuff(b.[values].value('/R[1]', 'nvarchar(max)'),
,
,
''),[count]
FROM (SELECT code,sum([count]) as [count]
FROM test
GROUP BY code) a
CROSS apply (
SELECT [values] =(
SELECT N',' + [values] FROM test
WHERE code = a.code
FOR XML PATH(''), ROOT('R'), TYPE
)
) b;
--方法二
---SQL2005中的新解法 使用XML
SELECT code, data=STUFF((SELECT ','+[values] FROM test t WHERE code=t1.code FOR XML PATH('')), 1, 1, ''),sum([count]) as [count]
FROM test t1
GROUP BY code
--查询结果
--001 aa,bb 3
--002 aaa,bbb,ccc 12
drop table test
相关文章
SQL server数据库log日志过大占用内存大的解决办法
SQL Server日志文件过大,随着时间的推移会占用很大的存储空间,下面这篇文章主要给大家介绍了关于SQL server数据库log日志过大占用内存大的解决办法,文中通过图文介绍的非常详细,需要的朋友可以参考下2024-05-05
SQL Server提示"选定的用户拥有对象,所以无法除去该用户”
今天在帮朋友弄一台服务器的时候当我需要删除一个数据库里的用户时,提示如下错误信息: "选定的用户拥有对象,所以无法除去该用户" 如何解决呢?2009-04-04
SqlServer 2022通过临时表和游标遍历方式逻辑处理获取目标数据
在SQL的存储过程,函数中,经常需要使用遍历(遍历table),其中游标、临时表等遍历方法很常用,本文就来介绍一下SqlServer 2022通过临时表和游标遍历方式逻辑处理获取目标数据,感兴趣的可以了解一下2024-04-04


最新评论