MySQL数据库练习题(单表查询,多表关联查询)(一)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: MySQL数据库练习题(单表查询,多表关联查询)

数据库练习题

DROP TABLE DEPT; 
CREATE TABLE DEPT 
(DEPTNO INT(2) PRIMARY KEY, 
DNAME VARCHAR(14) , 
LOC VARCHAR(13) ) ; 
DROP TABLE EMP; 
CREATE TABLE EMP 
(EMPNO INT(4) PRIMARY KEY, 
ENAME VARCHAR(10), 
JOB VARCHAR(9), 
MGR INT(4), 
HIREDATE DATE, 
SAL DECIMAL(7,2), 
COMM DECIMAL(7,2), 
DEPTNO INT(2) REFERENCES DEPT(DEPTNO)); 
INSERT INTO DEPT VALUES 
(10,'ACCOUNTING','NEW YORK'); 
INSERT INTO DEPT VALUES (20,'RESEARCH','DALLAS'); 
INSERT INTO DEPT VALUES 
(30,'SALES','CHICAGO'); 
INSERT INTO DEPT VALUES 
(40,'OPERATIONS','BOSTON'); 
INSERT INTO EMP VALUES 
(7369,'SMITH','CLERK',7902,'1980-12-17',800,NULL,20); 
INSERT INTO EMP VALUES 
(7499,'ALLEN','SALESMAN',7698,'1981-2-20',1600,300,30); 
INSERT INTO EMP VALUES 
(7521,'WARD','SALESMAN',7698,'1981-2-22',1250,500,30); 
INSERT INTO EMP VALUES 
(7566,'JONES','MANAGER',7839,'1981-4-2',2975,NULL,20); 
INSERT INTO EMP VALUES 
(7654,'MARTIN','SALESMAN',7698,'1981-9-28',1250,1400,30); 
INSERT INTO EMP VALUES 
(7698,'BLAKE','MANAGER',7839,'1981-5-1',2850,NULL,30); 
INSERT INTO EMP VALUES 
(7782,'CLARK','MANAGER',7839,'1981-6-9',2450,NULL,10); 
INSERT INTO EMP VALUES 
(7788,'SCOTT','ANALYST',7566,'1987-7-13',3000,NULL,20); 
INSERT INTO EMP VALUES 
(7839,'KING','PRESIDENT',NULL,'1981-11-17',5000,NULL,10); 
INSERT INTO EMP VALUES 
(7844,'TURNER','SALESMAN',7698,'1981-9-8',1500,0,30); 
INSERT INTO EMP VALUES 
(7876,'ADAMS','CLERK',7788,'1987-7-13',1100,NULL,20); 
INSERT INTO EMP VALUES 
(7900,'JAMES','CLERK',7698,'1981-12-3',950,NULL,30); 
INSERT INTO EMP VALUES 
(7902,'FORD','ANALYST',7566,'1981-12-3',3000,NULL,20); 
INSERT INTO EMP VALUES 
(7934,'MILLER','CLERK',7782,'1982-1-23',1300,NULL,10); 
DROP TABLE BONUS; 
CREATE TABLE BONUS 
( 
ENAME VARCHAR(10) , 
JOB VARCHAR(9) , 
SAL INT, 
COMM INT
) ; 
DROP TABLE SALGRADE; 
CREATE TABLE SALGRADE 
( GRADE INT, 
LOSAL INT, 
HISAL INT ); 
INSERT INTO SALGRADE VALUES (1,700,1200); 
INSERT INTO SALGRADE VALUES (2,1201,1400); 
INSERT INTO SALGRADE VALUES (3,1401,2000); 
INSERT INTO SALGRADE VALUES (4,2001,3000); 
INSERT INTO SALGRADE VALUES (5,3001,9999); 
COMMIT;

SQL练习题一 ——— 单表查询

1.选择部门30中的所有员工;

mysql> SELECT * FROM EMP 
WHERE DEPTNO=30;

2.列出所有办事员(CLERK)的姓名,编号和部门编号;

mysql> SELECT ENAME,EMPNO,DEPTNO FROM EMP 
WHERE JOB='CLERK';

3.找出奖金高于工资的员工;

mysql> SELECT ENAME FROM EMP 
WHERE IFNULL(COMM,0) > SAL;

4.找出奖金高于工资的60%的员工;

mysql> SELECT ENAME FROM EMP 
WHERE IFNULL(COMM,0) > SAL*0.6;

5.找出部门10中的所有经理(MANAGER)和部门20中所有的办事员(CLERK)的详细资料;

mysql> SELECT * FROM EMP 
WHERE (JOB='MANAGER' AND DEPTNO=10) OR (JOB='CLERK' AND DEPTNO=20);

6.找出部门10中所有的经理(MANAGER),部门20中所有办事员(CLERK),既不是经理又不是办事员但其工资大于或等于2000的所有员工的详细资料;

mysql> SELECT * FROM EMP
WHERE (JOB='MANAGER' AND DEPTNO=10) OR (JOB='CLERK' AND DEPTNO=20) OR JOB NOT IN ('MANAGER','CLERK') AND SAL>=2000;

7.找出收取奖金的员工的不同工作;

mysql> SELECT DISTINCT JOB FROM EMP 
WHERE IFNULL(COMM,0)>0;

8.找出不收取奖金或者收取的奖金低于100的员工;

mysql> SELECT * FROM EMP 
WHERE IFNULL(COMM,0)<=100;

9.找出各月倒数第三天受雇的所有员工;

mysql> SELECT * FROM EMP 
WHERE LAST_DAY(HIREDATE) - 2 = HIREDATE;

10.找出早于12年前受雇的员工;

mysql> SELECT * FROM EMP 
WHERE DATE_ADD(HIREDATE,INTERVAL 12 YEAR) < NOW();

11.以首字母大写的方式显示所有员工的姓名;

mysql> SELECT CONCAT(UPPER(LEFT(ENAME,1)),LOWER(SUBSTRING(ENAME,2,LENGTH(ENAME)-1))) FROM EMP

12.显示正好为5个字符的员工的姓名;

mysql> SELECT ENAME FROM EMP 
WHERE LENGTH(ENAME)=5;

13.显示不带有“R”的员工姓名;

mysql> SELECT ENAME FROM EMP 
WHERE ENAME NOT LIKE '%R%';

14.显示所有员工姓名的前三个字符;

mysql> SELECT LEFT(ENAME,3) FROM EMP;

15.显示所有员工的姓名,用“a”替换所有的“A”;

mysql> SELECT REPLACE(ENAME,'A','a') FROM EMP;

16.显示满10年服务年限的员工的姓名和受雇日期;

mysql> SELECT ENAME,HIREDATE FROM EMP WHERE DATE_ADD(HIREDATE,INTERVAL 10 YEAR) <= NOW();

17.显示员工的详细资料,按姓名排序;

mysql> SELECT * FROM EMP ORDER BY ENAME ASC;

18.显示员工的姓名和受雇日期,根据其服务年限,将最老的员工排在最前面;

mysql> SELECT ENAME,HIREDATE FROM EMP ORDER BY HIREDATE ASC;

19.显示所有员工的姓名、工作和工资,按工作的降序排序,若工作相同则按工资排序;

mysql> SELECT ENAME,JOB,SAL FROM EMP ORDER BY JOB DESC,SAL DESC;

20.显示所有员工姓名、加入公司的年份和月份,按受雇日期所在月排序,若月份相同则将最早年份的员工排在最前面;

mysql> SELECT ENAME,YEAR(HIREDATE) AS '年',MONTH(HIREDATE) AS '月' FROM EMP ORDER BY MONTH(HIRREDATE) ASC,YEAR(HIREDATE) ASC;

21.显示在一个月为30天的情况所有员工的日工资,忽略余数;

mysql> SELECT ENAME,FLOOR(SAL/30) AS '日薪' FROM EMP;

22.找出(任何年份的)2月受聘的所有员工;

mysql> SELECT * FROM EMP WHERE MONTH(HIREDATE)=2;

23.对于每个员工,显示其加入公司的天数;

mysql> SELECT ENAME,DATEDIFF(NOW(),HIREDATE) FROM EMP;

24.显示姓名字段的任何位置包含“A”的所有员工的姓名;

mysql> SELECT ENAME FROM EMP 
WHERE ENAME LIKE '%A%';

25.以年月日的方式显示所有员工的服务年限;

SELECT ENAME,FLOOR(DATEDIFF(NOW(),HIREDATE)/365) AS '年',
FLOOR(DATEDIFF(NOW(),HIREDATE)%365/30) AS '月', FLOOR(DATEDIFF(NOW(),HIREDATE)%365%30) AS '日' FROM EMP;

SQL练习题二 —— 多表关联

1.列出至少有一个员工的所有部门编号、名称,并统计出这些部门的平均工资、最低工资、最高工资

mysql> SELECT D.DEPTNO,D.DNAME,COUNT(E.EMPNO),AVG(SAL),MIN(SAL),MAX(SAL)
    -> FROM EMP E,DEPT D
    -> WHERE D.DEPTNO=E.DEPTNO
    -> GROUP BY D.DEPTNO,D.DNAME
    -> HAVING COUNT(E.EMPNO)>0;

2.列出薪金比SMITH或者ALLEN多的所有员工的编号、姓名、部门名称、其领导姓名

mysql> SELECT E.EMPNO,E.ENAME,D.DNAME,M.ENAME FROM EMP E,DEPT D,EMP M
    -> WHERE E.SAL>ANY(
    -> SELECT SAL
    -> FROM EMP
    -> WHERE ENAME IN ('SMITH','ALLEN'))
    -> AND E.DEPTNO=D.DEPTNO
    -> AND E.MGR=M.EMPNO;

3.列出所有员工的编号、姓名及其直接上级的编号、姓名,显示的结果按领导年工资的降序排列

mysql> SELECT E.EMPNO,E.ENAME,M.EMPNO,M.ENAME,(M.SAL+NVL(M.COMM,0))*12 INCOME
    -> FROM EMP E,EMP M
    -> WHERE E.MGR=M.EMPNO
    -> ORDER BY INCOME DESC;

4.列出雇佣日期早于其直接上级的所有员工的编号、姓名、部门名称、部门位置、部门人数

mysql> SELECT E.EMPNO,E.ENAME,D.DNAME,D.LOC,TEMP.COUNT
    -> FROM EMP E,DEPT D,EMP M,(
    -> SELECT DEPTNO DNO,COUNT(EMPNO) COUNT
    -> FROM EMP
    -> GROUP BY DEPTNO) TEMP
    -> WHERE E.MGR=M.EMPNO
    -> AND E.HIREDATE<M.HIREDATE
    -> AND E.DEPTNO=D.DEPTNO
    -> AND E.DEPTNO=TEMP.DNO;

5.列出部门名称和这些部门的员工信息(数量、平均工资),同时列出那些没有员工的部门

mysql> SELECT D.DNAME,COUNT(E.EMPNO),ROUND(IFNULL(AVG(E.SAL),0))
    -> FROM DEPT D,EMP E
    -> WHERE E.DEPTNO=D.DEPTNO
    -> GROUP BY D.DNAME;

6.列出所有CLERK的姓名及其部门名称,部门的人数,工资等级

mysql> SELECT E.ENAME,D.DNAME,TEMP.COUNT,S.GRADE 
FROM EMP E,DEPT D,(
    SELECT DEPTNO DNO,COUNT(EMMPNO) COUNT 
    FROM EMP 
    GROUP BY DEPTNO) TEMP,SALGRADE S 
WHERE JOB='CLERK' 
    AND E.DEPTNO=D.DEPTNO 
    AND D.DEPTNO=TEMP.DNO 
    AND E.SAL BETWEEN S.LOSAL AND S.HISAL;

7.列出最低薪金大于1500的各种工作及从事此工作的全部雇员人数及所在部门名称、位置、平均工资

select temp.job,temp.count,d.dname,d.loc,res.avg
from dept d,(
        select e.job job,count(e.empno) count
        from emp e
        group by e.job
        having min(e.sal)>1500) temp,
    emp e,(
        select deptno dno,avg(sal) avg
        from emp
        group by deptno) res
where e.deptno=d.deptno 
    and e.job=temp.job
    and e.deptno=res.dno;


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1天前
|
SQL 安全 Java
MyBatis-Plus条件构造器:构建安全、高效的数据库查询
MyBatis-Plus 提供了一套强大的条件构造器(Wrapper),用于构建复杂的数据库查询条件。Wrapper 类允许开发者以链式调用的方式构造查询条件,无需编写繁琐的 SQL 语句,从而提高开发效率并减少 SQL 注入的风险。
7 1
MyBatis-Plus条件构造器:构建安全、高效的数据库查询
|
5天前
|
SQL Java 关系型数据库
java连接mysql查询数据(基础版,无框架)
【10月更文挑战第12天】该示例展示了如何使用Java通过JDBC连接MySQL数据库并查询数据。首先在项目中引入`mysql-connector-java`依赖,然后通过`JdbcUtil`类中的`main`方法实现数据库连接、执行SQL查询及结果处理,最后关闭相关资源。
|
1天前
|
SQL NoSQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(5)作者——LJS[含MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页等详解步骤及常见报错问题所对应的解决方法]
MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页、INSERT INTO SELECT / FROM查询结合精例等详解步骤及常见报错问题所对应的解决方法
|
1天前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
12 1
|
1天前
|
SQL 关系型数据库 数据库
PostgreSQL性能飙升的秘密:这几个调优技巧让你的数据库查询速度翻倍!
【10月更文挑战第25天】本文介绍了几种有效提升 PostgreSQL 数据库查询效率的方法,包括索引优化、查询优化、配置优化和硬件优化。通过合理设计索引、编写高效 SQL 查询、调整配置参数和选择合适硬件,可以显著提高数据库性能。
8 1
|
2天前
|
SQL 关系型数据库 MySQL
定时任务频繁插入数据导致锁表问题 -> 查询mysql进程
定时任务频繁插入数据导致锁表问题 -> 查询mysql进程
10 1
|
2天前
|
SQL 关系型数据库 MySQL
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
6 0
|
19天前
|
SQL Go 数据库
【速存】深入理解Django ORM:编写高效的数据库查询
【速存】深入理解Django ORM:编写高效的数据库查询
43 0
|
16天前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
50 3
Mysql(4)—数据库索引
|
1天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
18 2