sql server 中合并某个字段值的实例

2022-11-12 09:44:39
内容摘要
这篇文章主要为大家详细介绍了sql server 中合并某个字段值的实例,具有一定的参考价值,可以用来参考一下。 对此感兴趣的朋友,看看idc笔记做的技术笔记! 有表如下: 【图片暂缺】
文章正文

这篇文章主要为大家详细介绍了sql server 中合并某个字段值的实例,具有一定的参考价值,可以用来参考一下。

对此感兴趣的朋友,看看idc笔记做的技术笔记!

有表如下:

【图片暂缺】

如何获得如下结果:

【图片暂缺】

解法

使用xml转换

代码如下:

代码如下:


 CREATE TABLE body  

(

ID int,

BODY nvarchar(20)

)

go

INSERT INTO body VALUES(1,'aaaa')

INSERT INTO body VALUES(2,'bbbb')

INSERT INTO body VALUES(1,'cccccc')

INSERT INTO body VALUES(3,'ddddd')

go

SELECT * FROM body

SELECT distinct a.ID,stuff((SELECT ','+BODY FROM body WHERE ID=a.ID FOR xml path('')),1,1,'') ASBODY

FROM

body a

--具体思路是这样的:

SELECT ','+BODY FROM body WHERE ID=a.ID FOR xml path('')

--这条语句的作用是按照a中的ID查找body表中ID=a.ID的所有记录,并把它转换成一个xml(关于将查询集转换成xml的文章,你可以去看看)

stuff((SELECT ','+BODY FROM body WHERE ID=a.ID FOR xml path('')),1,1,'')

--这条语句的作用是把生成的xml前面的一个逗号去掉并转化成标量值

--最后用一个distinct去掉重复的记录

注:关于sql server 中合并某个字段值的实例的内容就先介绍到这里,更多相关文章的可以留意

代码注释

作者:喵哥笔记

IDC笔记

学的不仅是技术,更是梦想!