国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

SQLSqlserver中如何將一列數據,不重復的拼接成一個字符串

2024-07-21 02:49:35
字體:
來源:轉載
供稿:網友
SQLSqlserver中如何將一列數據,不重復的拼接成一個字符串

  把一列數據拼接成一個字符串比較簡單:

declare @test varchar(500)set @test='';select @test=@test+name+',' from personselect @test

  但是如果數據中有重復選項,想去掉重復的就比較繞彎了。

declare @test varchar(500)set @test='';select distinct @test=@test+name+',' from personselect @test

加distinct是不行的,我在sql server 2008 版本測試起碼是不行的,只顯示了第一行的數據。

繞彎一下:

declare @test varchar(500)set @test='';with cte as(select distinct name+',' as namefrom person)select @test=@test+name from cte select @test 

其實這個思路下,用臨時表,表變量什么的都可以,但是用CTE比較簡潔。看來公用表表達式(CTE)有時候挺有用的。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 神池县| 道真| 黎城县| 四子王旗| 广西| 繁昌县| 兴文县| 华宁县| 肇源县| 习水县| 柳林县| 忻州市| 淮北市| 航空| 定边县| 怀宁县| 威海市| 黄平县| 镇坪县| 白玉县| 竹山县| 仙居县| 黄大仙区| 宝鸡市| 定西市| 五寨县| 桑日县| 龙里县| 西藏| 尤溪县| 遂川县| 六盘水市| 祁连县| 凤阳县| 桂东县| 漳平市| 高陵县| 旺苍县| 高平市| 松江区| 南部县|