Sql Server:多行合并成一行,并做分組統(tǒng)計的兩個方法
更新時間:2013年02月21日 09:59:24 作者:
Sql Server:多行合并成一行,并做分組統(tǒng)計的兩個方法,需要的朋友可以參考一下
復(fù)制代碼 代碼如下:
--創(chuàng)建 test 表 ,插入數(shù)據(jù)
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;
--方法一
--將多行合并成一行,并做分組統(tǒng)計
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
--查詢結(jié)果
--001 aa,bb 3
--002 aaa,bbb,ccc 12
drop table test
相關(guān)文章
SQL?server數(shù)據(jù)庫log日志過大占用內(nèi)存大的解決辦法
SQL Server日志文件過大,隨著時間的推移會占用很大的存儲空間,下面這篇文章主要給大家介紹了關(guān)于SQL?server數(shù)據(jù)庫log日志過大占用內(nèi)存大的解決辦法,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2024-05-05
SQLServer導(dǎo)出數(shù)據(jù)到MySQL實例介紹
本文為大家詳細(xì)介紹下從SQLServer導(dǎo)出數(shù)據(jù)并將數(shù)據(jù)導(dǎo)入到MySQL,具體的實現(xiàn)如下,感興趣的朋友可以參考下哈2013-07-07
SQL Server提示"選定的用戶擁有對象,所以無法除去該用戶”
今天在幫朋友弄一臺服務(wù)器的時候當(dāng)我需要刪除一個數(shù)據(jù)庫里的用戶時,提示如下錯誤信息: "選定的用戶擁有對象,所以無法除去該用戶" 如何解決呢?2009-04-04
SqlServer 2022通過臨時表和游標(biāo)遍歷方式邏輯處理獲取目標(biāo)數(shù)據(jù)
在SQL的存儲過程,函數(shù)中,經(jīng)常需要使用遍歷(遍歷table),其中游標(biāo)、臨時表等遍歷方法很常用,本文就來介紹一下SqlServer 2022通過臨時表和游標(biāo)遍歷方式邏輯處理獲取目標(biāo)數(shù)據(jù),感興趣的可以了解一下2024-04-04
數(shù)據(jù)結(jié)構(gòu)簡明備忘錄 線性表
線性表是線性結(jié)構(gòu)的抽象,線性結(jié)構(gòu)的特點是結(jié)構(gòu)中的數(shù)據(jù)元素之間存在一對一的線性關(guān)系。2010-03-03

