Home > Database > Mysql Tutorial > sqlserver 实现字符串的聚合

sqlserver 实现字符串的聚合

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Release: 2016-06-07 15:51:45
Original
1444 people have browsed it

关键字:sqlserver 2012,FOR XML PATH, 连接字符串 大家可能在工作中都遇到过需要聚合字符串的情况,例如: 实际的表数据如下 depart name 开发部 张三 开发部 李四 财务部 王二 财务部 麻子 运营部 路人甲 然后通过聚合,希望得到的结果 depart name 开发

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

 

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

实际的表数据如下

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

 

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

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

 

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

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

2,使用游标(cursor)

3,使用for xml path函数

 

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

代码如下

 

<span>select</span><span> depart, </span><span>[</span><span>name</span><span>]</span><span>=</span><span>stuff</span><span>((</span><span>select</span><span>'</span><span>,</span><span>'</span><span>+</span><span>[</span><span>name</span><span>]</span><span>from</span><span> tb t </span><span>where</span><span> id </span><span>=</span><span> tb.depart </span><span>for</span><span> xml path(</span><span>''</span><span>)) , </span><span>1</span><span> , </span><span>1</span><span> , </span><span>''</span><span>) </span><span>from</span><span> tb </span><span>group</span><span>by</span><span> depart</span>
Copy after login


 


 

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Issues
Problem with tp6 connecting to sqlserver database
From 1970-01-01 08:00:00
0
0
0
Unable to connect to SQL Server in Laravel
From 1970-01-01 08:00:00
0
0
0
Methods of parsing MYD, MYI, and FRM files
From 1970-01-01 08:00:00
0
0
0
SQLSTATE: User login failed
From 1970-01-01 08:00:00
0
0
0
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template