sql函数中怎样定义一个递增变量?

qin2006 2009-07-14 08:58:35
我要定义一个合并记录的函数,使原本结果
A AA1
A AA2
B BB1
B BB2
变成
A AA1,AA2
B BB1,BB2
下面的函数已经实现
create function Gettxt(@id char)
returns varchar(8000)
as
begin
declare @s varchar(8000)
set @s=''
select @s=@s +',' +txt from csdn where id=@id
--return @s
return stuff(@s,1,1,'')
end
go

现在要在合并记录处加上编号,如
A (1)AA1(2)AA2
请问该如何处理?
...全文
305 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
qin2006 2009-07-14
  • 打赏
  • 举报
回复
果然是高手如林,太感谢了!
叶子 2009-07-14
  • 打赏
  • 举报
回复
速度都好快呀
chuifengde 2009-07-14
  • 打赏
  • 举报
回复
ALTER  function Gettxt(@id VARCHAR(20)) 
returns varchar(8000)
as
begin
declare @s varchar(8000) ,@i INT
select @s='',@i=1
select @s=@s+'('+ltrim(@i)+')'+txt,@i=@i+1 from csdn where id=@id

return @s
end
Zoezs 2009-07-14
  • 打赏
  • 举报
回复

create function Gettxt(@id char)
returns varchar(8000)
as
begin
declare @s varchar(8000),@i int
set @s=''
set @i=1
select @s=@s +',(' +ltrim(@i)+')'+txt,@i=@i+1 from csdn where id=@id
--return @s
return stuff(@s,1,1,'')
end
go

pt1314917 2009-07-14
  • 打赏
  • 举报
回复

create function Gettxt(@id char)
returns varchar(8000)
as
begin
declare @s varchar(8000),@i int
set @s=''
set @i=1
select @s=@s +',(' +ltrim(@i)+')'+txt,@i=@i+1 from csdn where id=@id
--return @s
return stuff(@s,1,1,'')
end
go

liangCK 2009-07-14
  • 打赏
  • 举报
回复
create function Gettxt(@id char) 
returns varchar(8000)
as
begin
declare @i int
declare @s varchar(8000)
select @s='' ,@i=1
select @s=@s +',' +'(' +rtrim(@i) + ')'+txt,
@i=@i+1
from csdn where id=@id
--return @s
return stuff(@s,1,1,'')
end
go

34,594

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧