2行数据只有一列数据不同(不是主键),怎么合并成1行?

create table tb(
id int,
 value nvarchar(50)
) 
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
select * from tb
 --1. 创建处理函数
create function   dbo.f_value(@id int) 
returns  varchar(8000) 
as
begin declare  @str varchar(8000) 
set @str = ''
select  @str = @str + '/' + value  from  tb 
where id=@id 
return stuff(@str, 1, 1, '') 
end
GO 
-- 调用函数
select id, value =   dbo.f_value(id) from tb group by id
-- 删除表
drop table tb
-- 删除函数
drop function dbo.f_value
-----------------------------------------------

只需要把里面的SQL语句改成你想要的就行了

 

SQL Server:

CREATE FUNCTION dbo.f_position(@ClassID BIGINT)
RETURNS VARCHAR(8000)
AS
BEGIN DECLARE @str VARCHAR(8000)
SET @str = ''
SELECT @str = @str + (dbo.ufn_GetLocalizedCodeName([StevenhMembers].[Position], 'en-CA')) + '_' + isnull([StevenhMembers].[MemberName] ,'') + ',' 
FROM [ReadModel].[StevenhMembers] 
WHERE [StevenhMembers].[ClassID]=@ClassID AND dbo.ufn_GetLocalizedCodeName([StevenhMembers].[Position], 'en-CA') in ('Teacher', 'Monitor')
ORDER BY Position
RETURN substring(@str,1,len(@str)-1)  --去除最后一个逗号
END
go

select ClassID,MemberName = dbo.f_position(ClassID) from [Model].[StevenhMembers] WHERE dbo.ufn_GetLocalizedCodeName([StevenhMembers].[Position], 'en-CA') in ('Teacher', 'Monitor') GROUP BY ClassID
  



StevenhMembers表:






  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值