香港云主机最佳企业级服务商!

ADSL拨号VPS包含了中国大陆(联通,移动,电信,)

中国香港,国外拨号VPS。

当前位置:云主机 > MSSQL >

电信ADSL拨号VPS
联通ADSL拨号VPS
移动ADSL拨号VPS

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


时间:2020-10-31 14:24 作者:admin610456


有表如下:

如何获得如下结果:

解法

使用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去掉重复的记录

(责任编辑:admin)






帮助中心
会员注册
找回密码
新闻中心
快捷通道
域名登录面板
虚机登录面板
云主机登录面板
关于我们
关于我们
联系我们
联系方式

售前咨询:17830004266(重庆移动)

企业QQ:383546523

《中华人民共和国工业和信息化部》 编号:ICP备00012341号

Copyright © 2002 -2018 香港云主机 版权所有
声明:香港云主机品牌标志、品牌吉祥物均已注册商标,版权所有,窃用必究

云官方微信

在线客服

  • 企业QQ: 点击这里给我发消息
  • 技术支持:383546523

  • 公司总台电话:17830004266(重庆移动)
  • 售前咨询热线:17830004266(重庆移动)