第八周课后作业 数据库查询练习

简介: 第八周课后作业 数据库查询练习
一、数据库(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
相关文章
|
4天前
|
存储 数据库
Union All:数据库查询的得力助手
Union All:数据库查询的得力助手
|
11天前
|
存储 关系型数据库 MySQL
MySQL数据库的数据类型、语法和高级查询
MySQL数据库的数据类型、语法和高级查询
24 0
|
1天前
|
存储 NoSQL MongoDB
mongdb如何查询数据库表的创建时间
【6月更文挑战第29天】mongdb如何查询数据库表的创建时间
10 3
|
18天前
|
SQL 存储 安全
SQL入门与进阶:数据库查询与管理的实用指南
一、引言 在数字化时代,数据库已经成为各行各业存储、管理和分析数据的关键基础设施
|
3天前
|
运维 关系型数据库 分布式数据库
PolarDB产品使用问题之如何加快数据库查询速度
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
4天前
|
关系型数据库 MySQL 数据库
MySQL SELECT查询实战:练习题精选,提升你的数据库查询技能
MySQL SELECT查询实战:练习题精选,提升你的数据库查询技能
|
4天前
|
SQL 关系型数据库 MySQL
经验大分享:MySQL(三)数据库表的查询操作【重要】
经验大分享:MySQL(三)数据库表的查询操作【重要】
17 0
|
4天前
|
SQL Java 关系型数据库
Java中的JDBC编程:从数据库连接到高级查询
Java中的JDBC编程:从数据库连接到高级查询
|
4天前
|
SQL Java 数据库连接
Java中如何优化数据库查询性能?
Java中如何优化数据库查询性能?
|
6天前
|
时序数据库
时序数据库工具grafana里的$timeFilter查询1个小时内的数据如何写查询条件
【6月更文挑战第24天】时序数据库工具grafana里的$timeFilter查询1个小时内的数据如何写查询条件
84 0