实例3:按部门统计工资人数

简介: /* 实例3:按部门统计工资人数 可能的sql select deptno from dept; 查出所有的部门号 光标1 select sal from emp where deptno= 光标1中的值 */ set serveroutput on declare   --定义部门光标   cursor dcorsor is select deptno from dep

/*
实例3:按部门统计工资人数
可能的sql
select deptno from dept; 查出所有的部门号 光标1
select sal from emp where deptno= 光标1中的值
*/

set serveroutput on
declare
  --定义部门光标
  cursor dcorsor is select deptno from dept;
  pdno dept.deptno% TYPE;--保存部门号
  --定义某部门下的员工光标
  cursor cemp(dno number) is select sal from emp where deptno = dno;
  psal emp.sal% TYPE;--保存员工薪水
  --计数器
  count1 number;--6000
  count2 number;--3000~6000
  count3 number;--<3000
  psalTotal number;--工资总额
begin
  --获取部门号
  open dcorsor;
  loop
    --取部门
    fetch dcorsor into pdno;
    exit when dcorsor%notfound;
    --初始化
    count1 := 0;count2 := 0;count3 := 0;psalTotal :=0;
    --select sum(sal) into psalTotal from emp where empno=pdno;
    --取该部门中的员工
    open cemp(pdno);
      loop
        --取一个员工
        fetch cemp into psal;
        exit when cemp%notfound;
       
        --判断
        if psal <= 3000 then count3 := count3 + 1;
        ELSIF  psal >3000 and psal <= 6000 then count2 := count2 + 1;
        else  count1 := count1+ 1;
        end if;
        --工资总额
        psalTotal := psalTotal + psal;
      end loop;
    close cemp;--完成一个部门
   
    --保存结果
    insert into msg1 values(pdno, count3,count2,count1, psaltotal);
    commit;
   
  end loop;
  close dcorsor;
 
  dbms_output.put_line('完成');
end;
/
 
 
 
 
 
 
 
 
 
 
 
 
 

目录
相关文章
|
7月前
7-66 计算工资 (15 分)
7-66 计算工资 (15 分)
64 0
|
7月前
|
SQL
SQL 查找入职员工时间排名倒数第三的员工所有信息
SQL 查找入职员工时间排名倒数第三的员工所有信息
|
7月前
|
SQL
leetcode-SQL-1731. 每位经理的下属员工数量
leetcode-SQL-1731. 每位经理的下属员工数量
48 0
|
机器人
用八爪鱼RPA实现员工薪资管理,轻松拆分发放工资单!
RPA(机器人流程自动化)技术可以极大地压缩、优化现有的员工薪资管理流程。通过使用rpa机器人,可以自动化个税计算和申报,自动化工资单处理和发放等重复性、繁琐的任务。这样可以节省大量人力和时间,提高工作效率,减少错误和延误,提升员工满意度。同时,rpa还可以保证数据的准确性,提高工资管理的合规性,增强企业的信誉。
|
数据库
查询各年龄段人数
查询各年龄段人数
146 0
【SQL开发实战技巧】系列(十四):计算消费后的余额&计算银行流水累计和&计算各部门工资排名前三位的员工
本篇文章讲解的主要内容是:***通过模拟计算消费流水账及计算银行流水累计和讲解sum()over()函数使用场景、通过计算各部门工资排名前三位的员工小案例来介绍ROW_NUMBER、RANK、DENSE_RANK使用方法及区别***
【SQL开发实战技巧】系列(十四):计算消费后的余额&计算银行流水累计和&计算各部门工资排名前三位的员工
|
C++
C++实例员工工资系统
C++实例员工工资系统
112 0
|
数据库
LeetCode(数据库)- 部门工资前三高的所有员工
LeetCode(数据库)- 部门工资前三高的所有员工
96 0
LeetCode(数据库)- 部门工资前三高的所有员工
|
数据库
LeetCode(数据库)- 查询员工的累计薪水
LeetCode(数据库)- 查询员工的累计薪水
126 0
|
数据库
LeetCode(数据库)- 部门工资最高的员工
LeetCode(数据库)- 部门工资最高的员工
104 0