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

简介: 第八周课后作业 数据库查询练习
一、数据库(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
相关文章
|
3月前
|
SQL 数据库
LangChain-09 Query SQL DB With RUN GPT 查询数据库 并 执行SQL 返回结果
LangChain-09 Query SQL DB With RUN GPT 查询数据库 并 执行SQL 返回结果
43 2
|
1月前
|
存储 缓存 网络协议
数据库执行查询请求的过程?
客户端发起TCP连接请求,服务端通过连接器验证主机信息、用户名及密码,验证通过后创建专用进程处理交互。服务端进程缓存以减少创建和销毁线程的开销。后续步骤包括缓存查询(8.0版后移除)、语法解析、查询优化及存储引擎调用,最终返回查询结果。
29 6
|
2月前
|
SQL 安全 Java
MyBatis-Plus条件构造器:构建安全、高效的数据库查询
MyBatis-Plus 提供了一套强大的条件构造器(Wrapper),用于构建复杂的数据库查询条件。Wrapper 类允许开发者以链式调用的方式构造查询条件,无需编写繁琐的 SQL 语句,从而提高开发效率并减少 SQL 注入的风险。
42 1
MyBatis-Plus条件构造器:构建安全、高效的数据库查询
|
1月前
|
SQL JavaScript 程序员
数据库LIKE查询屡试不爽?揭秘大多数人都忽视的秘密操作符!
本文分析了因数据库中的不可见空白字符导致的数据查询问题,探讨了问题的成因与特性,并提出了使用 SQL 语句修复问题的有效方案。同时,总结了避免类似问题的经验和注意事项。
33 0
|
2月前
|
存储 缓存 固态存储
怎么让数据库查询更快
【10月更文挑战第28天】
43 2
|
2月前
|
存储 缓存 关系型数据库
怎么让数据库查询更快
【10月更文挑战第25天】通过以上综合的方法,可以有效地提高数据库查询的速度,提升应用程序的性能和响应速度。但在优化过程中,需要根据具体的数据库系统、应用场景和数据特点进行合理的调整和测试,以找到最适合的优化方案。
|
2月前
|
JSON JavaScript 关系型数据库
node.js连接GBase 8a 数据库 并进行查询代码示例
node.js连接GBase 8a 数据库 并进行查询代码示例
|
2月前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
368 1
|
2月前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
876 2
|
2月前
|
SQL 关系型数据库 数据库
PostgreSQL性能飙升的秘密:这几个调优技巧让你的数据库查询速度翻倍!
【10月更文挑战第25天】本文介绍了几种有效提升 PostgreSQL 数据库查询效率的方法,包括索引优化、查询优化、配置优化和硬件优化。通过合理设计索引、编写高效 SQL 查询、调整配置参数和选择合适硬件,可以显著提高数据库性能。
459 1

热门文章

最新文章