首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > 其他数据库 >

oracle查询职工人数最少的部门

2012-11-08 
oracle查询员工人数最少的部门--部门表create table t_dept( d_id number primary key , d_name varchar2(

oracle查询员工人数最少的部门

--部门表create table t_dept( d_id number primary key , d_name varchar2(20));create sequence dept_sequence start with 1increment by 1;--员工表create table t_emp( e_id number primary key , d_id number references t_dept(d_id), e_name varchar2(20));create sequence emp_sequence start with 100increment by 1;insert into t_dept values(dept_sequence.nextval,'一部');insert into t_dept values(dept_sequence.nextval,'二部');select * from t_dept;--“一部”插入4个员工insert into t_emp values(emp_sequence.nextval,2,'张一');insert into t_emp values(emp_sequence.nextval,2,'张二');insert into t_emp values(emp_sequence.nextval,2,'张三');insert into t_emp values(emp_sequence.nextval,2,'张四');--“二部”插入2个员工insert into t_emp values(emp_sequence.nextval,3,'李一');insert into t_emp values(emp_sequence.nextval,3,'李一');select * from t_emp;


目的:查询员工人数最少的部门

知识点:分组函数,排序,子查询,rownum

sql语句如下:

select * from (select count(*) coun,d_id deptId from t_emp group by d_id order by coun asc) where rownum=1


分析:

第一步:select count(*) coun,d_id deptId from t_emp group by d_id 查询t_emp表,根据部门d_id分组查询各部门的人数以d_id

第二步:select count(*) coun,d_id deptId from t_emp group by d_id order by coun asc 再orderby coun asc ,这样就按照人数升序排序,这样就第一条就是人数最少的

第三步:子查询,select * from (select count(*) coun,d_id deptId from t_emp group by d_id order by coun asc) where rownum=1 ,因为oracle不支持select top 1,当要取第一条数据的时候,要用到oracel给查询分配的rownum列,where rownum=1就取到第一条数据了

结果如下:

---------------------------------------

counn deptid

---------------------------------------

2           3

热点排行