已知每个部门有一个经理,统计输出部门名称、部门总人数、 总工资和部门经理。

--已知每个部门有一个经理,统计输出部门名称、部门总人数、
--总工资和部门经理。
--1.一个游标select deptno,count(*),sum(sal) from emp group by deptno;4个参数 v_deptname ,v_count,v_count_sal,v_dept_manager
--2.

set serveroutput on
declare
v_deptno number;
v_dept_name varchar2(20);
v_count number;
v_count_sal number;
v_dept_manager varchar2(20);
cursor c_dept is select deptno,count(*),sum(sal) from emp group by deptno;
begin


open c_dept;
dbms_output.put_line('--------------部门统计---------------');
dbms_output.put_line('部门名称    '||'人员总数  '||'薪资总和  '||'部门经理  ');
loop
fetch c_dept into v_deptno,v_count,v_count_sal;
exit when c_dept%notfound;
select dname into v_dept_name from dept where deptno = v_deptno;
select ename into v_dept_manager from emp where deptno = v_deptno and job = 'MANAGER';
dbms_output.put_line(rpad(v_dept_name,15)||rpad(v_count,6)||rpad(v_count_sal,10)||rpad(v_dept_manager,6));
end loop;
close c_dept;
end;

阅读更多
个人分类: Oracle数据库
上一篇稠化报表然后行转列
下一篇为雇员增加工资,从工资低的雇员开始,为每个人增加原工资的 10%,限定所增加的工资总额为 800 元,显示增加工资的人数和余额。
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭