sqlserver FOR XML PATH 語(yǔ)句的應(yīng)用
DECLARE @TempTable table(UserID int , UserName nvarchar(50));
insert into @TempTable (UserID,UserName) values (1,'a')
insert into @TempTable (UserID,UserName) values (2,'b')
select UserID,UserName from @TempTable FOR XML PATH
運(yùn)行這段腳本,將生成如下結(jié)果:
<row>
<UserID>1</UserID>
<UserName>a</UserName>
</row>
<row>
<UserID>2</UserID>
<UserName>b</UserName>
</row>
大家可以看到兩行數(shù)據(jù)生成了兩個(gè)節(jié)點(diǎn),修改一下PATH的參數(shù):
select UserID,UserName from @TempTable FOR XML PATH('lzy')
再次運(yùn)行上述腳本,將生成如下的結(jié)果:
<lzy>
<UserID>1</UserID>
<UserName>a</UserName>
</lzy>
<lzy>
<UserID>2</UserID>
<UserName>b</UserName>
</lzy>
可以看到節(jié)點(diǎn)變成,其實(shí)PATH() 括號(hào)內(nèi)的參數(shù)是控制節(jié)點(diǎn)名稱的,這樣的話大家可以看一下如果是空字符串(不是沒(méi)有參數(shù))會(huì)是什么結(jié)果?
select UserID,UserName from @TempTable FOR XML PATH('')
執(zhí)行上面這段腳本將生成結(jié)果:
<UserID>1</UserID>
<UserName>a</UserName>
<UserID>2</UserID>
<UserName>b</UserName>
這樣就不顯示上級(jí)節(jié)點(diǎn)了,大家知道在 PATH 模式中,列名或列別名被作為 XPath 表達(dá)式來(lái)處理,也就是說(shuō),是列的名字,這樣大膽試驗(yàn)一下不給指定列名和別名會(huì)是怎么樣?
select CAST(UserID AS varchar) + '',UserName + '' from @TempTable FOR XML PATH('')
運(yùn)行上面這句將生成結(jié)果
1a2b
所有數(shù)據(jù)都生成一行,而且還沒(méi)有連接字符,這樣的數(shù)據(jù)可能對(duì)大家沒(méi)有用處,還可以再變化一下:
select CAST(UserID AS varchar) + ',',UserName + '',';' from @TempTable FOR XML PATH('')
生成結(jié)果
1,a;2,b;
大家現(xiàn)在明白了吧,可以通過(guò)控制參數(shù)來(lái)生成自己想要的結(jié)果,例如:
select '{' + CAST(UserID AS varchar) + ',','"' +UserName + '"','}' from @TempTable FOR XML PATH('')
生成結(jié)果
{1,"a"}{2,"b"}
還可以生成其他格式,大家可以根據(jù)自己需要的格式進(jìn)行組合。
下面是一個(gè)數(shù)據(jù)統(tǒng)計(jì)的應(yīng)用,希望大家可以通過(guò)下面的實(shí)例想到更多的應(yīng)用
DECLARE @T1 table(UserID int , UserName nvarchar(50),CityName nvarchar(50));
insert into @T1 (UserID,UserName,CityName) values (1,'a','上海')
insert into @T1 (UserID,UserName,CityName) values (2,'b','北京')
insert into @T1 (UserID,UserName,CityName) values (3,'c','上海')
insert into @T1 (UserID,UserName,CityName) values (4,'d','北京')
insert into @T1 (UserID,UserName,CityName) values (5,'e','上海')
SELECT B.CityName,LEFT(UserList,LEN(UserList)-1) FROM (
SELECT CityName,
(SELECT UserName+',' FROM @T1 WHERE CityName=A.CityName FOR XML PATH('')) AS UserList
FROM @T1 A
GROUP BY CityName
)
生成結(jié)果(每個(gè)城市的用戶名)
北京 b,d
上海 a,c,e
相關(guān)文章
MSSQL2005 INSERT,UPDATE,DELETE 之OUTPUT子句使用實(shí)例
MSSQL2005 INSERT,UPDATE,DELETE使用實(shí)例,大家可以看下。2009-10-10
SQL2005重新生成索引的的存儲(chǔ)過(guò)程 sp_rebuild_index
本文分享了一個(gè)筆者自己整理的存儲(chǔ)過(guò)程,幫助技術(shù)人員快速的重新生成數(shù)據(jù)庫(kù)的索引,以減輕重復(fù)的工作,有需要的朋友,可以參考一下。2016-03-03
SQL Server CROSS APPLY和OUTER APPLY的應(yīng)用詳解
SQL Server數(shù)據(jù)庫(kù)操作中,在2005以上的版本新增加了一個(gè)APPLY表運(yùn)算符的功能2011-10-10
SQLServer2005 沒(méi)有日志文件(*.ldf) 只有數(shù)據(jù)文件(*.mdf) 恢復(fù)數(shù)據(jù)庫(kù)的方法
SQLServer2005 沒(méi)有日志文件(*.ldf) 只有數(shù)據(jù)文件(*.mdf) 恢復(fù)數(shù)據(jù)庫(kù)的方法2011-12-12
SQL2005CLR函數(shù)擴(kuò)展-繁簡(jiǎn)轉(zhuǎn)換的實(shí)現(xiàn)代碼
本篇文章是對(duì)繁簡(jiǎn)轉(zhuǎn)換的實(shí)現(xiàn)代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
收縮數(shù)據(jù)庫(kù)日志文件的方法(僅適用于mssql2005)
將數(shù)據(jù)庫(kù)日志文件變?yōu)?M大小代碼講解收縮mssql2005數(shù)據(jù)庫(kù)日志文件的方法,感興趣的你可不要錯(cuò)過(guò)了哈,希望本文可以幫助到你2013-02-02
SQL2005CLR函數(shù)擴(kuò)展-深入環(huán)比計(jì)算的詳解
環(huán)比就是本月和上月的差值所占上月值的比例。在復(fù)雜的olap計(jì)算中我們經(jīng)常會(huì)用到同比環(huán)比等概念,要求的上個(gè)維度的某個(gè)字段的實(shí)現(xiàn)語(yǔ)句非常簡(jiǎn)練,比如ssas的mdx語(yǔ)句類似[維度].CurrentMember.Prevmember就可以了2013-06-06
SQL Server 數(shù)據(jù)庫(kù)安全管理介紹
對(duì)于數(shù)據(jù)庫(kù)應(yīng)用程序,數(shù)據(jù)庫(kù)的安全是至關(guān)重要的。SQL Server的安全功能可以保護(hù)數(shù)據(jù)免受未經(jīng)授權(quán)的泄漏和篡改!下邊是對(duì)安全一章的總結(jié)2012-08-08

