--sql server 2000中的写法.
create table tb(name varchar(10), work varchar(10), startime int, endtime int , remark varchar(20))
_insert into tb values('张三', '程序员' , 1 , 3,'小伙子不错')
_insert into tb values('张三', '程序员' , 2 , null,'小伙子不错')
_insert into tb values('张三', '程序员' , 3 , null,'小伙子不错')
_insert into tb values('李四', '项目经理', 5 , null,'有前途')
_insert into tb values('李四', '项目经理', 7 , 10,'有前途')
_insert into tb values('王五', '技术总监', 10, null,'真棒')
go
--创建一个合并的函数
create function f_hb(@name varchar(10),@work varchar(10), @remark varchar(20))
returns varchar(8000)
as
begin
_declare @str varchar(8000)
set @str = ''
_select @str = @str + ',' + cast(time as varchar) from
(
_select name,work,remark,time = case when endtime is not null then cast(startime as varchar) + '-' + cast(endtime as varchar) else cast(startime as varchar) end from tb
) t
where name = @name and work = @work and remark = @remark
set @str = right(@str , len(@str) - 1)
return(@str)
End
go
--调用自定义函数得到结果:
_select distinct name ,work ,remark ,dbo.f_hb(name ,work ,remark) as time from tb
/*
name work remark time
---------- ---------- -------------------- ------------------
李四 项目经理 有前途 5,7-10
王五 技术总监 真棒 10
张三 程序员 小伙子不错 1-3,2,3