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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 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;


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
5天前
|
SQL Java 数据库连接
【潜意识Java】MyBatis中的动态SQL灵活、高效的数据库查询以及深度总结
本文详细介绍了MyBatis中的动态SQL功能,涵盖其背景、应用场景及实现方式。
52 6
|
30天前
|
SQL 关系型数据库 MySQL
【MySQL基础篇】多表查询(隐式/显式内连接、左/右外连接、自连接查询、联合查询、标量/列/行/表子查询)
本文详细介绍了MySQL中的多表查询,包括多表关系、隐式/显式内连接、左/右外连接、自连接查询、联合查询、标量/列/行/表子查询及其实现方式,一文全面读懂多表联查!
【MySQL基础篇】多表查询(隐式/显式内连接、左/右外连接、自连接查询、联合查询、标量/列/行/表子查询)
|
5天前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
63 0
|
1月前
|
存储 Oracle 关系型数据库
索引在手,查询无忧:MySQL索引简介
MySQL 是一款广泛使用的关系型数据库管理系统,在2024年5月的DB-Engines排名中得分1084,仅次于Oracle。本文介绍MySQL索引的工作原理和类型,包括B+Tree、Hash、Full-text索引,以及主键、唯一、普通索引等,帮助开发者优化查询性能。索引类似于图书馆的分类系统,能快速定位数据行,极大提高检索效率。
63 8
|
1月前
|
SQL 关系型数据库 MySQL
MySQL 窗口函数详解:分析性查询的强大工具
MySQL 窗口函数从 8.0 版本开始支持,提供了一种灵活的方式处理 SQL 查询中的数据。无需分组即可对行集进行分析,常用于计算排名、累计和、移动平均值等。基本语法包括 `function_name([arguments]) OVER ([PARTITION BY columns] [ORDER BY columns] [frame_clause])`,常见函数有 `ROW_NUMBER()`, `RANK()`, `DENSE_RANK()`, `SUM()`, `AVG()` 等。窗口框架定义了计算聚合值时应包含的行。适用于复杂数据操作和分析报告。
84 11
|
1月前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
63 3
|
1月前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
81 3
|
1月前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE &#39;log_%&#39;;`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
96 2
|
1月前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
273 15
|
1月前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。