求个SQL语句,返回的某字段数据合成一个值,用逗号分隔

表1名称标志A1B1A3C2A2D5得到名称标志A1,2,3<---主要是这一行怎么得出来B1C2D5~~... 表1
名称 标志
A 1
B 1
A 3
C 2
A 2
D 5

得到
名称 标志
A 1,2,3 <---主要是这一行怎么得出来
B 1
C 2
D 5
~~
展开
 我来答
小林哥哒哒哒
2013-03-20 · TA获得超过240个赞
知道答主
回答量:213
采纳率:0%
帮助的人:88.5万
展开全部
--1. 创建处理函数
create table tb(id int, value varchar(10))
insert into tb values(1, 'aa')
insert into tb values(1, 'bb')
insert into tb values(2, 'aaa')
insert into tb values(2, 'bbb')
insert into tb values(2, 'ccc')
go

CREATE FUNCTION dbo.f_str(@id int)
RETURNS varchar(8000)
AS
BEGIN
DECLARE @r varchar(8000)
SET @r = ''
SELECT @r = @r + ',' + value FROM tb WHERE id=@id
RETURN STUFF(@r, 1, 1, '')
END
GO

-- 调用函数SELECt id, value = dbo.f_str(id) FROM tb GROUP BY id
drop table tbdrop function dbo.f_str
/*
id value
----------- -----------
1 aa,bb
2 aaa,bbb,ccc
(所影响的行数为 2 行)
*/
syx54
2013-03-20 · TA获得超过7378个赞
知道大有可为答主
回答量:6567
采纳率:83%
帮助的人:2755万
展开全部
没有这种语句的吧!知道了也告诉我?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式