求个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
~~ 展开
名称 标志
A 1
B 1
A 3
C 2
A 2
D 5
得到
名称 标志
A 1,2,3 <---主要是这一行怎么得出来
B 1
C 2
D 5
~~ 展开
2个回答
展开全部
--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 行)
*/
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 行)
*/
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询