在Oracle的PLSQL中执行,提示缺少表达式,在SQlServer中执行的结果是对的,求大神解答!!
select部门号,[姓名]=stuff((select','+[姓名]from员工twhere部门号=员工.部门号forxmlpath('')),1,1,'')from...
select 部门号, [姓名] = stuff((select ',' + [姓名] from 员工 t
where 部门号 = 员工.部门号 for xml path('')) , 1 , 1 , '')
from 员工
group by 部门号
select 部门号,姓名 = dbo.fun_combName(部门号) from 员工 group by 部门号 order by 部门号;
以上函数执行之后说函数无效……
对不起我分不多还问你那么多…… 展开
where 部门号 = 员工.部门号 for xml path('')) , 1 , 1 , '')
from 员工
group by 部门号
select 部门号,姓名 = dbo.fun_combName(部门号) from 员工 group by 部门号 order by 部门号;
以上函数执行之后说函数无效……
对不起我分不多还问你那么多…… 展开
2个回答
展开全部
先定义个FUNCION(如名称为function_name):传入参数DEPTNO,在FUNCTION里面定义个游标,检索该DEPTNO下所有员工的姓名,最后将所有员工的姓名RETURN出来
然后用select deptno, function_name(deptno) from dept;
望采纳
然后用select deptno, function_name(deptno) from dept;
望采纳
追问
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;
不在公司,没法验证对不对,不过那表名字段什么最好换成英文的。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询