一、数据库(employee)中有数据表 部门表(dept) 字段名 字段类型 宽度 说明 备注 deptno char 10 主键 部门编号 dname varchar 10 非NULL 部门名称 loc varchar 20 非NULL 所在城市 雇员表(emp) 字段名 字段类型 宽度 说明 备注 empno char 10 主键 员工编号 ename varchar 20 非NULL 员工姓名 job varchar 10 工作 mrg char 10 直属领导 hiredate date 雇佣日期 sal decimal(7,2) 非NULL 工资 comm decimal(7,2) 奖金 deptno char 10 所属部门 工资等级表(grade) 字段名 字段类型 宽度 说明 备注 grade char 10 主键 工资等级 losal float 非NULL 最低工资 hisal float 非NULL 最高工资
首先对应创建表:
create database employee; use employee; (部门表) create table dept( deptno char(10) primary key comment "部门编号", dname varchar(10) not null comment "部门名称", loc varchar(20) not null comment "所在城市"); (雇员表) create table emp( empno char(10) primary key comment "员工编号", ename varchar(20) not null comment "员工姓名", job varchar(10) comment "工作", mrg char(10) comment "直属领导", hiredate date comment "雇佣日期", sal decimal(7,2) not null comment "工资", comm decimal(7,2) comment "奖金", deptno char(10) comment "所属部门"); (工资等级表) create table grade( grade char(10) primary key comment "工资等级", losal float not null comment "最低工资", hisal float not null comment "最高工资");
1. 列出所有员工的姓名及其直接上级的姓名。
select ename,(select ename from emp where e.mrg=e.empno) from emp e;
解析:
列:是员工姓名以及上级姓名
表格:emp
条件:员工的直属领导编号=员工编号
因为是所有员工以及上级姓名,所以外部并没有其他条件仅仅就这一张表
所以在选择属性中间进行查找对应表中员工的直属领导姓名
2. 查出至少有一个员工的部门。显示部门编号、部门名称、部门位置、部门人数。
select d.,z.cnt from dept d,( select deptno,count() as cnt from emp group by deptno) z where d.deptno=z.deptno and z.cnt>=1;
列:部门编号、部门名称、部门位置、部门人数
表:dept,emp
条件:z.cnt>=1
思路:
因为列中的前三个属性在第一张表中,部门人数需要从第二张表emp中统计出来,所以需要两张表。
第一张表需要需要所有属性,另一张表需要部门编号以及人数我们进行生成出来,再整体进行条件筛选。
这是from后面的两张表,再进行筛选count>=1 以及部门编号相同的即可
3. 列出所有文员的姓名及其部门名称,部门的人数。
select e.ename,d.name,e.cnt from dept d,(select ename,deptno,count(*)as cnt from emp) e where e.ename = “文员” and e.deptno=d.deptno
列:文员的姓名及其部门名称,部门的人数
表:dept,emp
条件:emp.ename = “文员”
4. 列出薪金比laoZhang高的所有员工
select ename from emp where sal>(select sal from emp where ename like “laoZhang”);
5. 列出受雇日期早于直接上级的所有员工的编号、姓名、部门名称。
select e.empno,e.ename,d.dname from emp e,dept d where hiredate<(select hiredate from emp where empno in (e.mrg)) and e.deptno=d.deptno;
列:员工的编号、姓名、部门名称
表:emp,dept
条件:受雇日期早于直接上级(这里可以直接用日期比较)
思路:
首先进行比对emp中日期前后,在进行对应员工所属部门与dept中的筛选
6. 列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门。
select dname,emp.* from dept left join emp on dept.deptno=emp.deptno;
列:部门名称,员工信息
表:emp,dept 进行左外连接
条件:列出没有员工与有员工的
7. 列出最低薪金大于15000的各种工作及从事此工作的员工人数。
select job,count(*) from emp e group by job having min(sal)>15000;
进行分组,然后设置最低薪金大于15000
8. 列出在销售部工作的员工的姓名,假定不知道销售部的部门编号。
select ename from emp; where deptno=(select deptno from dept where dname=“销售部”);
思路:
不知道销售部的部门编号,那么从部门名称中寻找部门编号,然后进行比对查找
9. 列出薪金高于公司平均薪金的所有员工信息,所在部门名称,上级领导,工资等级。
select e.*,d.dname,m.ename,g.grade from emp e,from emp m,dept d,grade g where e.sal>(select avg(sal) from emp) and e.mrg=m.empno and e.deptno=d.deptno and e.sal between g.losal and g.hisal;
列:员工所有信息,所在部门名称,上级领导姓名,工资等级
表:emp,dept,grade
条件:薪水高于公司平均 雇员表与部门表有相同编号 找到对应的上级名称 最后根据对应工资找到对应的等级(4个)
10.列出与xiaoLiu从事相同工作的所有员工及部门名称。
select e.*,d.dname from emp e,dept d where e.job=(select job from emp where ename=“xiaoLiu”) and e.deptno=d.deptno;
列:所有员工,部门名称
表:emp,dept
条件:找到与xiaoliu相同工作的员工 对应员工表中部门编号找到部门表中的部门名称(2)
11.列出薪金高于在部门30工作的所有员工的薪金的员工姓名和薪金、部门名称。
select e.ename,e.sal,d.dname from emp e,dept d where e.deptno=d.deptno and e.sal>all(select sal from emp where deptno=30);
列:员工姓名和薪金、部门名称
表:emp,dept
条件:两张表对应的部门名称,sal>all(对应薪资)
12.列出在每个部门工作的员工数量、平均工资。
select deptno,count(*),avg(sal) from emp group by deptno