select 部门号, [姓名] = stuff((select ',' + [姓名] from 员工 t
where 部门号 = 员工.部门号 for xml path('')) , 1 , 1 , '')
from 员工
group by 部门号
select 部门号,姓名 = dbo.fun_combName(部门号) from 员工 group by 部门号 order by 部门号;
以上函数执行之后说函数无效……
对不起我分不多还问你那么多……
create function fun_combName1(@teamname varchar(32))
returns varchar(4000)
as
begin
declare @temp varchar(4000)
set @temp = ''
select @temp = @temp+';'+姓名 from 员工 where 部门号 = @teamname
set @temp = stuff(@temp,1,1,'')
return @temp
end
看了下,有些语法是PLSQL中没有的,所以报错了。
create function fun_combName1(teamname varchar2)
return varchar2
as
temp varchar2(4000) default '';
cursor c_name is select 姓名 from 员工 where 部门号 = teamname;
begin
for v_name in c_name loop
temp:=temp:||v_name.姓名;
end loop;
return temp;
end;
不在公司,没法验证对不对,不过那表名字段什么最好换成英文的。