加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sqlserver 实现字符串的聚合

发布时间:2020-12-12 14:25:17 所属栏目:MsSql教程 来源:网络整理
导读:关键字:sqlserver 2012,FOR XML PATH,连接字符串 ? ??? 大家可能在工作中都遇到过需要聚合字符串的情况,例如: 实际的表数据如下 depart name 开发部 张三 开发部 李四 财务部 王二 财务部 麻子 运营部 路人甲 ? 然后通过聚合,希望得到的结果 depart nam
depart name 开发部 张三 开发部 李四 财务部 王二 财务部 麻子 运营部 路人甲

?

然后通过聚合,希望得到的结果

depart name 开发部 张三,李四 财务部 王二,麻子 运营部 路人甲

?

实际上,有三种方法可以实现这样的结果

1,使用自定义方法(function)

2,使用游标(cursor)

3,使用for xml path函数

?

这里主要介绍第三种,因为理论上代码的复杂度和开销都相对会小一点。

代码如下

?

select depart,[name] = stuff((select ',' + [name] from tb t where id = tb.depart for xml path('')),1,'') from tb group by depart

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

关键字:sqlserver 2012,FOR XML PATH,连接字符串

?

??? 大家可能在工作中都遇到过需要聚合字符串的情况,例如:

实际的表数据如下

    推荐文章
      热点阅读