SQL|SQL Server实现group_concat功能的详细实例
目录
- 一、实现
- 二、原理分析
- 2.1、FOR XML PATH的作用
- 2.2、STUFF函数
- 2.2.1、STUFF函数在本SQL的作用
- 2.2.2、STUFF函数语法
- 2.3、sql语分分析
- 2.3.1、一个简单的group by
- 2.3.2、在select语句后面加上子查询
- 2.3.3、去掉子查询结果集的第一个分隔符
- 总结
一、实现 #tmp表内容如下:
文章图片
实现group_concat的sql语句为:
SelectRegionID,STUFF((SELECT ',' + T.c1FROM #tmp TWHERE A.regionid = T.regionidFOR XML PATH('')), 1, 1, '') as group_concat FROM #tmp AGroup byRegionID
实现效果如下:
文章图片
二、原理分析
2.1、FOR XML PATH的作用
FOR XML PATH 的作用是将查询结果集以XML形式展现,将多行的结果,展示在同一行,例如:
select c1 from #tmp where RegionID = 41653
其结果集如下:
文章图片
select c1 from #tmp where RegionID = 41653 FOR XML PATH('')
【SQL|SQL Server实现group_concat功能的详细实例】当sql语句加上 FOR XML PATH('') 后,其结果集输出是:
文章图片
具体输出的字符如下:
通过字符拼接后可以把xml信息清除,并以指定的字符进行分割:30.326809 30.327982 30.347933 30.388104 30.392830 30.367931 30.368052 30.367842 30.357318 30.357349 30.357349
select ',' + c1 from #tmp where RegionID = 41653 FOR XML PATH('')
文章图片
此时已基本达到group_concat的效果,但第一个字符串有分隔符需要去掉。
2.2、STUFF函数
2.2.1、STUFF函数在本SQL的作用 我们使用STUFF函数的目的是把第一个分隔符去掉。先看看效果:
文章图片
上图可以看到,STUFF函数把字符串“abcdefg”中的第一个字符“a”删除。
使用该函数我们可以很轻松的把上图得到的结果集去掉第一个逗号分隔符:
文章图片
需要详细了解STUFF函数可继续看该函数的语法,没兴趣的可以忽略。
2.2.2、STUFF函数语法 STUFF函数的作用是将字符串插入到另一个字符串中。它从第一个字符串的开始位置删除指定长度的字符,然后将第二个字符串插入到第一个字符串的开始位置。其语法为:
STUFF(character_expression , start , length , replaceWith_expression)
character_expression:字符数据的表达式,可以是常量、变量,也可以是字符列或二进制数据列。
start:一个整数值(从1开始),指定删除和插入的开始位置。start的类型可以是bigint。
? 如果 start 为负或为零,则返回空字符串。
? 如果 start 的长度大于第一个 character_expression,则返回空字符串。
length:一个整数,指定要删除的字符数。length的类型可以是 bigint。
? 如果 length 为负,则返回空字符串。
? 如果 length 的长度大于character_expression,则最多可以删除到character_expression 中的最后一个字符。
? 如果 length 为零,则不删除字符直接在指定位置插入内容。
replaceWith_expression:字符数据的表达式,可以是常量、变量,也可以是字符列或二进制数据列。此表达式从 start 开始替换 length 个字符的character_expression。
? 如果 replaceWith_expression 为 NULL,则在不插入任何内容的情况下删除字符。
2.3、sql语分分析
2.3.1、一个简单的group by
Select RegionID FROM #tmp AGroup by RegionID
这个sql各位看官都十分熟悉,已经没什么好说的了。
2.3.2、在select语句后面加上子查询
Select RegionID,(SELECT ',' + T.c1FROM #tmp TWHERE A.regionid = T.regionidFOR XML PATH('')) FROM #tmp AGroup by RegionID
在上述简单的group by语句基础上加入一个select里的子查询,其结果如下:
文章图片
在该子查询中,当外层的group by返回结果集中的第一行RegionID为41653时,这个值被子查询的where条件所使用,相当于:
SELECT ',' + T.c1FROM #tmp TWHERE T.regionid = 41653FOR XML PATH('')
因为FOR XML PATH把多行记录打平成一条记录,因此此时的返回结果为:
文章图片
接着第group by返回结果集中的第二行45761传入该子查询,依次类似上面描述的执行,直到所有外层的值遍历完成。
2.3.3、去掉子查询结果集的第一个分隔符
SelectRegionID,STUFF((SELECT ',' + T.c1FROM #tmp TWHERE A.regionid = T.regionidFOR XML PATH('')), 1, 1, '') as group_concat FROM #tmp AGroup byRegionID
利用STUFF函数,去掉了第一个逗号,完成了最终sql语句。
总结 到此这篇关于SQL Server实现group_concat功能的文章就介绍到这了,更多相关SQLServer实现group_concat内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- [PostgreSql]生产级别数据库安装要考虑哪些问题()
- springboot+mybatis拦截器方法实现水平分表操作
- Mysql中如何查看执行计划
- MySQL|MySQL 中字符集详细介绍
- Java利用TCP实现服务端向客户端消息群发的示例代码
- mysql|mysql 字符串正则表达式及说明
- 原来MySQL|原来MySQL 数据类型也可以优化
- 腾讯云|极致效率,云原生数据库TDSQL-C安身立命的根本
- java|SSM在线学习网站的设计与实现毕业设计源码011451
- 微信小程序底部导航栏实现