字符串串联聚合专用解决方案

本文介绍了一种使用SQL进行数据分组和聚合的方法,具体展示了如何利用GROUP BY结合子查询和FOR XML PATH实现字符串的连接操作。此外,还介绍了STUFF函数用于去除首个字符的技巧。

1.建表语句

use tempdb;
go
if object_id('dbo.Groups') is not null
 drop table dbo.Groups;
go

create table dbo.Groups
(
 groupid varchar(10) not null,
 memberid int not null,
 string varchar(10) not null,
 val int not null,
 primary key(groupid, memberid)
);

insert into dbo.Groups(groupid, memberid, string, val)
values('a', 3, 'stra1', 6)
insert into dbo.Groups(groupid, memberid, string, val)
values('a', 9, 'stra2', 7)
insert into dbo.Groups(groupid, memberid, string, val)
values('b', 2, 'strb1', 3)
insert into dbo.Groups(groupid, memberid, string, val)
values('b', 4, 'strb2', 7)
insert into dbo.Groups(groupid, memberid, string, val)
values('b', 5, 'strb3', 3)
insert into dbo.Groups(groupid, memberid, string, val)
values('b', 9, 'strb4', 11)
insert into dbo.Groups(groupid, memberid, string, val)
values('c', 3, 'strc1', 8)
insert into dbo.Groups(groupid, memberid, string, val)
values('c', 7, 'strc2', 10)
insert into dbo.Groups(groupid, memberid, string, val)
values('c', 9, 'strc3', 12)

dbo.Groups表内容如下:

a3stra16
a9stra27
b2strb13
b4strb27
b5strb33
b9strb411
c3strc18
c7strc210
c9strc312

我们现在需要按groupid分组,如后聚合连接string的值。语句如下:

select groupid,
 stuff((
  select ',' + string as [text()]
  from dbo.Groups as G2
  where G2.groupid = G1.groupid
  order by memberid
  for xml path('')), 1, 1, '') as string
from dbo.Groups as G1
group by groupid;

该子查询主要返回当前组内所有字符串的有序路径(ordered path)。由于为Path子句提供了一个空字符串作为输入,所以未产生包装器(wrapper)元素。没有别名的表达式(如,',' + string)或应用别名[text()]的表达式是内联的,它的内容将作为文本节点。使用STUFF函数是为了移除第一个逗号(通过把它替换为空字符串)。

 

转载于:https://www.cnblogs.com/strugglepcx/archive/2010/09/07/1820860.html

(1)普通用户端(全平台) 音乐播放核心体验: 个性化首页:基于 “听歌历史 + 收藏偏好” 展示 “推荐歌单(每日 30 首)、新歌速递、相似曲风推荐”,支持按 “场景(通勤 / 学习 / 运动)” 切换推荐维度。 播放页功能:支持 “无损音质切换、倍速播放(0.5x-2.0x)、定时关闭、歌词逐句滚动”,提供 “沉浸式全屏模式”(隐藏冗余控件,突出歌词与专辑封面)。 多端同步:自动同步 “播放进度、收藏列表、歌单” 至所有登录设备(如手机暂停后,电脑端打开可继续播放)。 音乐发现与管理: 智能搜索:支持 “歌曲名 / 歌手 / 歌词片段” 搜索,提供 “模糊匹配(如输入‘晴天’联想‘周杰伦 - 晴天’)、热门搜索词推荐”,结果按 “热度 / 匹配度” 排序。 歌单管理:创建 “公开 / 私有 / 加密” 歌单,支持 “批量添加歌曲、拖拽排序、一键分享到社交平台”,系统自动生成 “歌单封面(基于歌曲风格配色)”。 音乐分类浏览:按 “曲风(流行 / 摇滚 / 古典)、语言(国语 / 英语 / 日语)、年代(80 后经典 / 2023 新歌)” 分层浏览,每个分类页展示 “TOP50 榜单”。 社交互动功能: 动态广场:查看 “关注的用户 / 音乐人发布的动态(如‘分享新歌感受’)、好友正在听的歌曲”,支持 “点赞 / 评论 / 转发”,可直接点击动态中的歌曲播放。 听歌排行:个人页展示 “本周听歌 TOP10、累计听歌时长”,平台定期生成 “全球 / 好友榜”(如 “好友中你本周听歌时长排名第 3”)。 音乐圈:加入 “特定曲风圈子(如‘古典音乐爱好者’)”,参与 “话题讨论(如‘你心中最经典的钢琴曲’)、线上歌单共创”。 (2)音乐人端(创作者中心) 作品管理: 音乐上传:支持 “无损音频(FLAC/WAV)+ 歌词文件(LRC)+ 专辑封面” 上传,填写 “歌曲信息
### MySQL 中的字符串拼接函数及其用法 #### CONCAT 函数 `CONCAT` 是 MySQL 提供的一个基本字符串拼接函数,可以将多个字符串按顺序连接成一个单一的字符串。如果任意参数为 `NULL`,则整个结果会返回 `NULL`[^2]。 以下是 `CONCAT` 的语法结构: ```sql CONCAT(str1, str2, ..., strN) ``` 当调用此函数时,它会依次将传入的字符串参数组合在一起。例如: ```sql SELECT CONCAT('Hello', ' ', 'World'); -- 输出: Hello World ``` 需要注意的是,如果有任何一个参数是 `NULL`,那么最终的结果也会变成 `NULL`。 --- #### CONCAT_WS 函数 `CONCAT_WS` 表示 **Concatenate With Separator**(带分隔符的拼接),它的第一个参数是一个指定的分隔符,后续参数则是待拼接的字符串列表。与 `CONCAT` 不同之处在于,即使某些参数为 `NULL`,也不会影响其他部分的正常拼接。 其语法如下所示: ```sql CONCAT_WS(separator, str1, str2, ..., strN) ``` 下面的例子展示了如何利用该方法来处理可能含有空值的数据列: ```sql SELECT CONCAT_WS(', ', 'Apple', NULL, 'Banana', 'Orange'); -- 输出: Apple, Banana, Orange ``` 可以看到,在上述例子中尽管存在一个 `NULL` 值,但它并未干扰到其余项之间的逗号分割效果。 --- #### GROUP_CONCAT 函数 不同于前两者仅限于单行操作,`GROUP_CONCAT` 主要应用于多行数据汇总场景下完成组级别的串联合并工作。它可以接受额外选项来自定义输出样式比如去重(`DISTINCT`)、排序规则 (`ORDER BY`) 和自定义间隔标记等等[^3]。 这里给出一段示范代码片段说明其具体应用方式: ```sql SELECT department_id, GROUP_CONCAT(employee_name SEPARATOR '; ') AS employees_list FROM employees GROUP BY department_id; ``` 这段查询语句将会把每一个部门内的员工姓名通过分号加空格的形式串联起来形成一个新的字段叫做employees_list。 --- ### 总结对比表 | 功能需求 | 推荐使用的函数 | |----------------------|--------------------| | 单纯两三个字段简单相加 | `CONCAT` | | 需要加入特定符号作为区隔 | `CONCAT_WS` | | 对一组记录进行整体聚合显示 | `GROUP_CONCAT` | 每种工具都有各自适用范围,请依据实际业务逻辑选取最合适的解决方案
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值