题目:企业发放的奖金根据利润提成。
- 利润(I)低于或等于10万元时,奖金可提10%;
- 利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%;
- 20万到40万之间时,高于20万元的部分,可提成5%;
- 40万到60万之间时高于40万元的部分,可提成3%;
- 60万到100万之间时,高于60万元的部分,可提成1.5%;
- 高于100万元时,超过100万元的部分按1%提成。
输入当月利润I,求应发放奖金总数?
drop function if exists test;
create function test( i int )
returns DOUBLE
BEGIN
declare bonus DOUBLE;
declare bonus1 ,bonus2 ,bonus4 ,bonus6 ,bonus10 DOUBLE;
set bonus1=100000*0.1;
set bonus2=bonus1+100000*0.075;
set bonus4=bonus2+200000*0.05;
set bonus6=bonus4+200000*0.03;
set bonus10=bonus6+400000*0.015;
if(i<=100000) then
set bonus=i*0.1;
elseif(i<=200000) then
set bonus=bonus1+(i-100000)*0.075;
elseif(i<=400000) then
set bonus=bonus2+(i-200000)*0.05;
elseif(i<=600000) then
set bonus=bonus4+(i-400000)*0.03;
elseif(i<=1000000) then
set bonus=bonus6+(i-600000)*0.015;
elseif(i>1000000) then
set bonus=bonus10+(i-1000000)*0.01;
end if;
return bonus;
end;