作者:HappyFlyStone轉載請注明出處通常情況下我們對相同數值項目進行分組求和,那是相當的簡單啦,只要select..groupby加聚合函數就行了,可是對于串一類的項目進行合并時就不這么簡單了,同樣分解一個按指定分隔符分隔的串或分析指定位置的串,在下我們通常是創(chuàng)建一" />

欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

SQL2005下利用XML進行項目的合并與拆分

系統(tǒng) 1904 0

SQL2005 下利用 XML 進行項目的合并與拆分 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

作者: HappyFlyStone

轉載請注明出處

  通常情況下我們對相同數值項目進行分組求和,那是相當的簡單啦,只要 select .. group by 加聚合函數就行了,可是對于串一類的項目進行合并時就不這么簡單了,同樣分解一個按指定分隔符分隔的串或分析指定位置的串,在下我們通常是創(chuàng)建一個函數,然后分組或提取就行了,現我們主要討論在下利用 xml 來完成這個工作。

1 、先來一個簡單點,如下的例子對 aaa 相同的項目合并。

------------------------------------------------------------------------

-- Author: HappyFlyStone

-- Date : 2009-01-04 20:57:59

-- Ver: Microsoft SQL Server 2005 - 9.00.2047.00 (Intel X86)

-- Apr 14 2006 01:12:25

-- Copyright (c) 1988-2005 Microsoft Corporation

-- Standard Edition on Windows NT5.0(Build 2195: Service Pack 4)

--

------------------------------------------------------------------------

-- Test Data: tb

IF OBJECT_ID ( 'tb' ) IS NOT NULL

DROP TABLE tb

Go

CREATE TABLE tb ( aaa INT , bbb INT )

Go

INSERT INTO tb

SELECT 1 , 2 UNION ALL

SELECT 1 , 3 UNION ALL

SELECT 1 , 4 UNION ALL

SELECT 2 , 2 UNION ALL

SELECT 2 , 5

GO

-- 查詢 1

select

aaa ,

[values] = stuff ( replace ( replace (( select [bbb]

from tb

where aaa = t . aaa for xml AUTO ),

'"/><tb bbb="' , ',' ),

'"/>' , '' ), 1 , 9 , '' )

from tb t

group by aaa

-- 查詢 2

SELECT *

FROM (

SELECT DISTINCT

aaa

FROM tb

) A

OUTER APPLY(

SELECT

[bbb] = STUFF ( REPLACE ( REPLACE (

(

SELECT [bbb] FROM tb N

WHERE aaa = A . aaa

FOR XML AUTO

), '<N bbb="' , ',' ), '"/>' , '' ), 1 , 1 , '' )

) N

-- 查詢 3

select

aaa ,

[values] = stuff (( select ',' + ltrim ( [bbb] )

from tb t

where aaa = tb . aaa for xml path ( '' )), 1 , 1 , '' )

from tb

group by aaa

drop table tb

-- 查詢結果

/*

aaa values

----------- ---------

1 2,3,4

2 2,5

(2 行受影響 )

*/

2 、來個兩個表關聯(lián)操作并實現行列轉換的

------------------------------------------------------------------------

-- Author: HappyFlyStone

-- Date : 2009-01-04 20:57:59

-- Ver: Microsoft SQL Server 2005 - 9.00.2047.00 (Intel X86)

-- Apr 14 2006 01:12:25

-- Copyright (c) 1988-2005 Microsoft Corporation

-- Standard Edition on Windows NT5.0(Build 2195: Service Pack 4)

--

------------------------------------------------------------------------

-- Test Data: ta

IF OBJECT_ID ( 'ta' ) IS NOT NULL

DROP TABLE ta

Go

CREATE TABLE ta ( pid INT , tid INT , name NVARCHAR ( 6 ))

Go

INSERT INTO ta

SELECT 1 , 1 , 'hy3500' UNION ALL

SELECT 1 , 2 , 'aabbcc' UNION ALL

SELECT 2 , 3 , '1111' UNION ALL

SELECT 2 , 4 , '2222'

GO

-- Test Data: tb

IF OBJECT_ID ( 'tb' ) IS NOT NULL

DROP TABLE tb

Go

CREATE TABLE tb ( NAME NVARCHAR ( 2 ), id INT )

Go

INSERT INTO tb

SELECT ' 型號 ' , 1 UNION ALL

SELECT ' 參數 ' , 2

GO

--Start

SELECT t . [name] , A , B

FROM (

SELECT

B . [NAME] ,

CAST (( SELECT [name] FROM TA WHERE PID = A . PID FOR XML PATH ( '' )) AS XML ) AS X

FROM TA A

border-right: medium none; padding-right: 0cm; border-top: medium none; padding-left: 0cm; padding-bottom: 0cm; margin: 0cm 0cm 0pt; border-left: medium none; padding-top: 0cm; border-bottom: medium n

分享到:
評論

SQL2005下利用XML進行項目的合并與拆分


更多文章、技術交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 成人在线网 | 九九爱国产| 天天干天天操天天爽 | 99这里只有精品 | 亚洲国产视频在线观看 | 性猛交ⅹxxx乱巴西 无人精品乱码一区二区三区 | 欧美亚洲黄色 | 日韩精品成人a在线观看 | 欧美国产精品一区二区免费 | 亚洲无线| 久久亚洲精品视频 | 亚洲精品综合网 | 青青青青久久久久国产的 | 成人做爽爽爽爽免费国产软件 | 奇米在线观看视频 | 免费一区二区三区 | 国产精品天堂 | 丁香六月婷婷激情 | 99精品一区二区免费视频 | 久久蜜桃av一区二区天堂 | 欧美les免费观看网站 | 欧美一区二区三区四区视频 | 精品一区二区三区视频 | 色精品一区二区三区 | 欧美大码毛片在线播放 | 精久久久| 综合第一页 | 国产精品影视 | 精品伊人久久久大香线蕉欧美 | 台湾三级无遮挡在线播放 | 欧美日韩亚洲区久久综合 | 久久久久国产亚洲日本 | 日韩一级片在线观看 | 久久久久无码国产精品一区 | 亚洲 欧美 另类 综合 偷拍 | 国产黄色在线观看 | 蜜桃在线视频 | 亚洲欧洲日本在线观看 | 欧美高清第一页 | 99精品视频在线观看免费专区 | 91精品久久久久久久久网影视 |