• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Sql Server:多行合并成一行,并做分组统计的两个方法

mysql 搞代码 4年前 (2022-01-09) 57次浏览 已收录 0个评论

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,

本文来源gaodai.ma#com搞##代!^码@网*

bb 3
–002 aaa,bbb,ccc 12

drop table test


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Sql Server:多行合并成一行,并做分组统计的两个方法

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址