`

每个部门,,每个职位的平均工资和平均奖金(平均值包括没有奖金),如果平均奖金大于300,显示“奖金不错”,如果平均奖金100 到300,显示“奖金一般”,如果平

阅读更多

---方法1

select decode(deptno,10,'财务部',20,'研发部',30,'销售部','未知部门') dept,round(avg(sal),0),round(avg(nvl(comm,0)),0),case 

when avg(nvl(comm,0))>300 then '奖金不错'

when avg(nvl(comm,0))>100 and avg(nvl(comm,0))<300 then '奖金一般'

when avg(nvl(comm,0))<100 then '几乎没奖金' 

end status 

from emp

group by deptno 

order by deptno desc,avg(sal) desc;

 

---方法2

select decode(deptno,10,'财务部',20,'研发部',30,'销售部','未知部门') dept,round(avg(sal),0),round(avg(nvl(comm,0)),0),

decode(

 sign(round(avg(nvl(comm,0)),0)-300),

       1,'奖金不错',

       0,'奖金不错',

       -1,decode(

             sign(round(avg(nvl(comm,0)),0)-100),

               1,'奖金一般',

               0,'奖金一般',

               -1,'几乎没有奖金'

             )

)

as status from emp

group by deptno

order by deptno desc,avg(sal) desc;

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics