Rachel2014 2014-04-29 13:55
浏览 959

大家好,我用mysql写存储过程自动产生编号,运行之后编号只有1,请问哪儿有问题呢?

BEGIN
DECLARE subjectNo1 char(8);
DECLARE subjectNo2 char(8);
DECLARE nowYear char(4);
DECLARE Num DECIMAL;

select date_format(now(),'%Y') into nowYear from DUAL;
select ifnull(max(Subject_No),'0') into subjectNo1
from subject
where Subject_No like nowYear||'%';
if subjectNo1='0' then
set subjectNo2=nowYear||'0001';
else
set Num=to_number(substr(subjectNo1,5,4))+1;
if Num<10 then set subjectNo2=nowYear||'000'||ltrim(to_char(Num));
elseif Num<100 then set subjectNo2=nowYear||'00'||ltrim(to_char(Num));
elseif Num<1000 then set subjectNo2=nowYear||'0'||ltrim(to_char(Num));
else
set subjectNo2=nowYear||ltrim(to_char(Num));
end if;
end if;
set newSubjectNo=subjectNo2;
END

  • 写回答

0条回答

    报告相同问题?

    悬赏问题

    • ¥30 这是哪个作者做的宝宝起名网站
    • ¥60 版本过低apk如何修改可以兼容新的安卓系统
    • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
    • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
    • ¥50 有数据,怎么用matlab求全要素生产率
    • ¥15 TI的insta-spin例程
    • ¥15 完成下列问题完成下列问题
    • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
    • ¥15 YoloV5 第三方库的版本对照问题
    • ¥15 请完成下列相关问题!