C 练习实例2 之mysql实现

题目:企业发放的奖金根据利润提成。

  • 利润(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;

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值