手机
当前位置:查字典教程网 >编程开发 >mssql数据库 >Sql Server:多行合并成一行,并做分组统计的两个方法
Sql Server:多行合并成一行,并做分组统计的两个方法
摘要:复制代码代码如下:--创建test表,插入数据CREATETABLEtest(codevarchar(50),[values]varchar...

复制代码 代码如下:

--创建 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:多行合并成一行,并做分组统计的两个方法】相关文章:

SQL 合并多行记录的方法总汇

SQL Server各种日期计算方法(收藏)

SQL Sever中使用SQL语句实现把重复行数据合并为一行并用逗号分隔

删除SQL Server数据中指定的重复记录

SQL Server中统计每个表行数的快速方法

SQL Server 2005 定时执行SQL语句的方法

sql里将重复行数据合并为一行数据使用逗号进行分隔

SQL Server 2008 密钥 key 使用方法

SQL Server 2008 R2安装配置方法图文教程

SQLserver 2005文件和文件组的作用说明

精品推荐
分类导航