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
大家好,我用mysql写存储过程自动产生编号,运行之后编号只有1,请问哪儿有问题呢?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
0条回答
悬赏问题
- ¥30 这是哪个作者做的宝宝起名网站
- ¥60 版本过低apk如何修改可以兼容新的安卓系统
- ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
- ¥50 有数据,怎么建立模型求影响全要素生产率的因素
- ¥50 有数据,怎么用matlab求全要素生产率
- ¥15 TI的insta-spin例程
- ¥15 完成下列问题完成下列问题
- ¥15 C#算法问题, 不知道怎么处理这个数据的转换
- ¥15 YoloV5 第三方库的版本对照问题
- ¥15 请完成下列相关问题!