在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 部门号;

以上函数执行之后说函数无效……

对不起我分不多还问你那么多……
展开
 我来答
shq1989shq
2012-07-26
知道答主
回答量:17
采纳率:100%
帮助的人:11.6万
展开全部
先定义个FUNCION(如名称为function_name):传入参数DEPTNO,在FUNCTION里面定义个游标,检索该DEPTNO下所有员工的姓名,最后将所有员工的姓名RETURN出来
然后用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;
不在公司,没法验证对不对,不过那表名字段什么最好换成英文的。
CCLEY0
2012-07-28
知道答主
回答量:10
采纳率:0%
帮助的人:1.6万
展开全部
test 结果楼上的回答正确
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式