MySQL-35个DQL练手题(难)

2024-09-06 07:28
文章标签 mysql dql 35 database 练手

本文主要是介绍MySQL-35个DQL练手题(难),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第1题

  1. 取得每个部门最高薪水的人员名称
    第一步:取得每个部门最高薪水
select max(sal) topsal, deptno from emp group by deptno;

在这里插入图片描述
第二步:将上面第一步的查询结果当做一张临时表t,进行表连接,条件是:t.deptno=e.deptno and t.maxsal=e.sal

select e.ename, t.* from emp e join (select max(sal) topsal, deptno from emp group by deptno) t on e.deptno=t.deptno and e.sal=t.topsal;

在这里插入图片描述

第2题

哪些人的薪水在部门的平均薪水之上

select t.*, e.ename, e.sal from emp e join (select avg(sal) avgsal, deptno from emp group by deptno) t on e.sal>t.avgsal and t.deptno=e.deptno;

在这里插入图片描述

第3题

取得每个部门平均薪水的等级

select t.*, s.grade from salgrade s join (select deptno, avg(sal) avgsal from emp group by deptno) t on t.avgsal between s.losal and s.hisal;

在这里插入图片描述

第4题

取得部门中(所有人的)平均的薪水等级

select avg(t.grade), t.deptno from (select e.ename, e.sal, e.deptno, s.grade from emp e join salgrade s on e.sal between s.losal and s.hisal) t group by t.deptno;
select e.deptno, avg(s.grade) from emp e join salgrade s on e.sal between s.losal and s.hisal group by e.deptno;

在这里插入图片描述

第5题

不准用组函数(Max),取得最高薪水(给出两种解决方案)
自己想的:

select max(sal) from emp;
select a.sal from emp a where not exists (select b.sal from emp b where b.sal > a.sal);

在这里插入图片描述
第一种方案:按照薪资降序排列,取第一个。

select ename, sal from emp order by sal desc limit 1;

第二种方案:采用表的自连接方式。

select ename, sal from emp where sal not in (select distinct a.sal from emp a join emp b on a.sal<b.sal);

在这里插入图片描述

第6题

取得平均薪水最高的部门的部门编号(至少给出两种解决方案)
第一种方案:降序排列取第一个(其实不准确, 比如有多个部门平均工资都是最高,这种情况可以用 having)

select deptno, avg(sal) avgsal from emp group by deptno order by avgsal desc limit 1;

在这里插入图片描述
第二种方案:max函数。
第一步:获取不同部门平均工资

select deptno, avg(sal) avgsal from emp group by deptno;

在这里插入图片描述
第二步:获取最大工资
这个重命名 t 是必需的

select max(avgsal) maxsal from (select deptno, avg(sal) avgsal from emp group by deptno) t;

在这里插入图片描述
第三步:

select deptno, avg(sal) avgsal from emp group by deptno having avgsal=(select max(avgsal) maxsal from (select deptno, avg(sal) avgsal from emp group by deptno) t);
select deptno, avg(sal) avgsal from emp group by deptno having avgsal=(select avg(sal) avgsal from emp group by deptno order by avgsal desc limit 1);

在这里插入图片描述

第7题

取得平均薪水最高的部门的部门名称

select deptno, avg(sal) avgsal from emp group by deptno order by avgsal desc limit 1;
select deptno, avg(sal) avgsal from emp group by deptno having avgsal=(select avg(sal) avgsal from emp group by deptno order by avgsal desc limit 1);

在这里插入图片描述

select t.avgsal, d.dname from dept d join (select deptno, avg(sal) avgsal from emp group by deptno having avgsal=(select avg(sal) avgsal from emp group by deptno order by avgsal desc limit 1)) t on t.deptno=d.deptno;
select d.dname,avg(e.sal) as avgsal from emp e join dept d on e.deptno=d.deptno group by d.dname order by avgsal desc limit 1;

在这里插入图片描述

第8题

求平均薪水的等级最低的部门的部门名称

select t.*,s.grade from (select d.dname,avg(e.sal) as avgsal from emp e join dept d on e.deptno = d.deptno group by d.dname) t join salgrade s on t.avgsal between s.losal and s.hisal order by s.grade asc limit 1;

在这里插入图片描述

这篇关于MySQL-35个DQL练手题(难)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1141385

相关文章

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

《mysql出现ERROR2003(HY000):Can‘tconnecttoMySQLserveron‘localhost‘(10061)的解决方法》本文主要介绍了mysql出现... 目录前言:第一步:第二步:第三步:总结:前言:当你想通过命令窗口想打开mysql时候发现提http://www.cpp

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

MySQL错误代码2058和2059的解决办法

《MySQL错误代码2058和2059的解决办法》:本文主要介绍MySQL错误代码2058和2059的解决办法,2058和2059的错误码核心都是你用的客户端工具和mysql版本的密码插件不匹配,... 目录1. 前置理解2.报错现象3.解决办法(敲重点!!!)1. php前置理解2058和2059的错误

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

MySQL Workbench 安装教程(保姆级)

《MySQLWorkbench安装教程(保姆级)》MySQLWorkbench是一款强大的数据库设计和管理工具,本文主要介绍了MySQLWorkbench安装教程,文中通过图文介绍的非常详细,对大... 目录前言:详细步骤:一、检查安装的数据库版本二、在官网下载对应的mysql Workbench版本,要是

mysql数据库重置表主键id的实现

《mysql数据库重置表主键id的实现》在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了... 目录关键语法演示案例在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,当我们