a_xiaokou 2016-01-15 08:42 采纳率: 0%
浏览 2646

oracle自定义函数如何转成mysql函数

这是oracle自定义的函数,怎么把他转成mysql的
create or replace function fun_return_zjxl(in_taskId varchar2,
in_work_no varchar2)
return varchar2 is
v_sum number(10);--质检平均完成量
v_num NUMBER(10);--质检个人完成量
v_qualitied_cnt NUMBER(10);
v_result varchar2(20);--0异常,1高于平均值,2低于平均值
begin
v_result:=0;
select (SELECT count(*) FROM ZJ_SCORE ZS WHERE ZS.TASK_ID=in_taskId and zs.status=3)/(select count(zut.user_id) from zj_user_task zut where zut.task_id=in_taskId) into v_sum from dual ;
SELECT count(zs.id) into v_num FROM ZJ_SCORE ZS WHERE ZS.TASK_ID=in_taskId and zs.status=3 and zs.work_no=in_work_no;
if(v_num>=v_sum) then
v_result:=1;
else
v_result:=2;
end if;
return(v_result);
end fun_return_zjxl;

  • 写回答

1条回答

  • 太平牛市 2016-01-15 14:04
    关注

    oracle与sql基础语法其实差不多
    无非就是一些基础语法问题 比如赋值的时候 oracle需要:= 而sql只要直接=号就可以了

    create function fun_return_zjxl(in_taskId varchar2,
    in_work_no varchar2)
    return varchar2 is
    v_sum number(10);--质检平均完成量
    v_num int--质检个人完成量
    v_qualitied_cnt int
    v_result varchar(20);--0异常,1高于平均值,2低于平均值
    begin
    set v_result=0;
    select (SELECT count(*) FROM ZJ_SCORE ZS WHERE ZS.TASK_ID=in_taskId and zs.status=3)/(select count(zut.user_id)
    from zj_user_task zut where zut.task_id=in_taskId) into v_sum from dual ;
    SELECT count(zs.id) into v_num FROM ZJ_SCORE ZS WHERE ZS.TASK_ID=in_taskId and zs.status=3 and zs.work_no=in_work_no;
    if(v_num>=v_sum)
    v_result:=1;
    else
    v_result:=2;
    return(v_result);
    end

    
    

    你试下这个

    评论

报告相同问题?

悬赏问题

  • ¥15 求差集那个函数有问题,有无佬可以解决
  • ¥15 MATLAB动图问题
  • ¥15 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
  • ¥15 解riccati方程组
  • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名