SQL12 获取每个部门中当前员工薪水最高的相关信息

        题目:获取每个部门中当前员工薪水最高的相关信息 

         注意了,这道题目,分组函数只能查出来:每个部门的最高薪水,group by  dept_no ,根据部门分组,绝对不能group by dept_no,emp_no,不能根据(部门、员工编号)联合分组:

(select e1.dept_no, max(s1.salary) as salary from dept_emp e1 joinsalaries s1one1.emp_no = s1.emp_no group by e1.dept_no ) s2  
方法一: 三张表联查

select e.dept_no , e.emp_no , s.salary as maxSalary
from dept_emp e joinsalaries s 
one.emp_no = s.emp_no   join (select e1.dept_no, max(s1.salary) as salary from dept_emp e1 joinsalaries s1one1.emp_no = s1.emp_no group by e1.dept_no ) s2  #这是s2表ons2.dept_no = e.dept_no  and s2.salary = s.salary 
where e.to_date='9999-01-01' and s.to_date='9999-01-01'
order by e.dept_no;

优化:通过使用 WITH 语句创建了一个名为 max_salaries 的临时表,这样可以更清晰地理解查询的逻辑。

WITH max_salaries AS (SELECT e1.dept_no, MAX(s1.salary) AS max_salaryFROM salaries s1INNER JOIN dept_emp e1 ON e1.emp_no = s1.emp_noGROUP BY e1.dept_no
)
SELECT e.dept_no,e.emp_no,s.salary AS max_salary
FROM dept_emp e 
JOINsalaries s ON e.emp_no = s.emp_no
JOINmax_salaries ms ON e.dept_no = ms.dept_no AND s.salary = ms.max_salary
ORDER BY e.dept_no;
方法二:居然还能这样玩!!!   in 的用法可以使用元组形式
select d.dept_no,d.emp_no,s.salary
from dept_emp as d
join salaries as s
on d.emp_no = s.emp_no
where (d.dept_no,salary) in (# in 的用法可以使用元组形式 :找出部门和对应的最高工资   
select d.dept_no,max(s.salary) salaryfrom dept_emp as djoin salaries as son d.emp_no = s.emp_nogroup by d.dept_no
)order by d.dept_no


        在 MySQL 中,子查询中使用 IN 操作符时,需要确保子查询返回的结果列数与外部查询中的比较列数相匹配。在这个查询中,子查询返回三列 (dept_no, max_salary, from_date),而外部查询试图将其与两列 (dept_no, salary) 进行比较,这导致了错误:

    为了解决这个问题,可以将子查询的结果限制为两列,即 (dept_no, max_salary),并且在外部查询中使用这两列进行比较。以下是修改后的查询:

        这样就能够正确地比较子查询和外部查询的列数,并得到想要的结果。 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/819001.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

.Net使用Elastic.Clients.Elasticsearch连接Elasticsearch8

文章目录 1、elasticsearch.yml配置2、生成证书指纹3、使用Elastic.Clients.Elasticsearch连接4、参考 1、elasticsearch.yml配置 单一节点配置 node.name: node-1path.data: /var/lib/elasticsearch path.logs: /var/log/elasticsearchnetwork.host: localhost http.port: 9…

Linux命令学习—linux 网络基础与网络服务管理

1.1、网卡的配置 1.1.1、修改网卡的配置文件 网卡配置文件的目录: /etc/sysconfig/network-scripts 网卡的配置文件类型: ifconfig-ethX 有线网卡的配置文件 ifconfig-ethX:X 有线网卡的虚拟网卡的配置文件 ifconfig-wlanX 无线网卡的配置文件 网…

学习一门语言的方法和套路(B站转述)

视频链接 up虽然长相英(ping)俊(ping),但是讲的干活,没恰饭。 学习流程: 1.快速阅读,掌握概况 2.深入细节内容 例如:java (JDBC)、html 、netty 不管三七二十一,先了解套路,再深入研究。 高…

2024软考中项考哪个版本?应该该如何备考?

2024年1月,备受瞩目的软考中级系统集成项目管理工程师官方教程终于迎来了久违的大改版。为确保广大考生能够有充足的准备时间,软考中项的考试时间被顺延至同年11月,届时,这也将成为软考中项首次依据第3版考纲进行的考试。 新教材核…

计算机网络之CIDR

快速了解CIDR CIDR 表示的是什么? 单个IP地址:当你看到一个CIDR表示法,如192.168.1.1/32,它表示一个单独的具体IP地址。/32表示所有32位都是网络部分,没有主机部分,因此它指的是单一的IP地址。 一个IP地址…

typescript playwright 笔记

录制调式 命令 npx playwright codegen url npx playwright codegen https://www.baidu.com/typescript 中 format 和 split 的使用 import * as util from util;const str1 hellow %s; const format util.format; const str2 format(str1, word);// 提取taskId const str3…

非线性特征曲线线性化插补器(CODESYS 完整ST代码)

1、如何利用博途PLC和信捷PLC实现非线性特征曲线的线性化可以参考下面文章链接: 非线性特征曲线线性化(插补功能块SCL源代码+C代码)_scl直线插补程序-CSDN博客文章浏览阅读382次。信捷PLC压力闭环控制应用(C语言完整PD、PID源代码)_RXXW_Dor的博客-CSDN博客闭环控制的系列文章…

【Canvas与艺术】绘制磨砂黄铜材质Premium Quality徽章

【关键点】 渐变色的使用、斜纹的实现、底图的寻觅 【成果图】 ​​​​​​​ 【代码】 <!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8"/> <head><tit…

计算机网络:数据链路层 - CSMA/CA协议

计算机网络&#xff1a;数据链路层 - CSMA/CA协议 CSMA/CA概述帧间间隔工作原理退避算法虚拟载波监听 CSMA/CA概述 讲解CSMA/CA之前&#xff0c;我们回顾一下CSMA/CD的三个特性&#xff1a; 多址接入MA&#xff1a;多个主机连接在一条总线上&#xff0c;竞争使用总线 载波监听…

腾讯云轻量应用服务器端口开启教程

腾讯云轻量应用服务器端口怎么打开&#xff1f;在轻量应用服务器控制台的防火墙中开启端口&#xff0c;本文腾讯云百科txybk.com以80端口为例&#xff0c;来详细说下轻量应用服务器端口打开教程&#xff0c;另外可以在腾讯云百科 txy.wiki 查看当前轻量服务器最新的优惠券和配置…

大隐市苏州

大隐隐于市的典型&#xff1a;苏州。 中国四大园林&#xff0c;二个在苏州&#xff0c;实际上看多逛多了苏州园林&#xff0c;其它地方的园林真的就是太不精致了~~~~ 哈哈&#xff0c;莫打莫打。 将山水装入庭院&#xff0c;情怀显露山水间。 看似宅男一个&#xff0c;实则依旧…

康耐视visionpro-CoglntersectLineLineTool操作说明工具详细说明

◆CogIntersectLineLineTool功能说明&#xff1a; 创建两条线的交点 备注&#xff1a;在“Geometry-Intersection”选项中的所有工具都是创建两个图形的交点工具&#xff0c;其中包括圆与圆的交点、线与圆的交点、线与线的交点、线与圆的交点等&#xff0c;工具使用的方法相似。…

视频国标学习

总体介绍 GB/T28181协议&#xff0c;全名叫《安全防范视频监控联网系统信息传输、交换、控制技术要求》&#xff0c;是由中国国家标准委员会发布的一种国家级的标准。它主要对视频监控系统的各个方面做了明确的规定&#xff0c;使得不同厂商生产的视频监控设备能够相互连通&am…

一种基于OpenCV的图片倾斜矫正方法

需求描述&#xff1a; 对倾斜的图片进行矫正&#xff0c;返回倾斜角度和矫正后的图片。 解决方法&#xff1a; 1、各种角度点被投影到一个累加器阵列中&#xff0c;其中倾斜角度可以定义为在最大化对齐的搜索间隔内的投影角度。 2、以不同的角度旋转图像&#xff0c;并为每…

代码随想录刷题day52|最长递增子序列最长连续递增序列最长重复子序列

文章目录 day52学习内容一、最长递增子序列1.1、动态规划五部曲1.1.1、 确定dp数组&#xff08;dp table&#xff09;以及下标的含义1.1.2、确定递推公式1.1.3、 dp数组如何初始化1.1.4、确定遍历顺序1.1.5、输出结果 1.2、代码 二、最长连续递增序列2.1、动态规划五部曲2.1.1、…

参会记录|全国多媒体取证暨第三届多媒体智能安全学术研讨会(MAS‘2024)

前言&#xff1a;2024年4月13日上午&#xff0c;我与实验室的诸位伙伴共聚江西南昌的玉泉岛大酒店&#xff0c;参加了为期一天半的全国多媒体取证暨第三届多媒体智能安全学术研讨会&#xff08;MAS’2024&#xff09;。本届学术研讨会由江西省计算机学会、江西省数字经济学会主…

基于单片机恒温控制系统的开发研究

摘要:温度是工业生产的过程中最为常见的工艺参数,温度控制直接影响工业生产产品的质量,特别在机械、冶金、化工、建材、石油等工业生产中温度控制占据着重要的作用。虽然目前温度控制有多种方式,但是在专业化和高指标要求等方面还有待进一步开发研究。随着科学技术的进步,…

PHP:IntelliJ IDEA 配置 PHP 开发环境及导入PHP项目

在创建PHP项目之前我们需要安装PHP插件&#xff0c;安装步骤如下&#xff1a;Windows&#xff1a;IntelliJ IDEA Ultimate 安装 PHP 插件-CSDN博客 1、导入已有PHP项目&#xff0c;导入之后选择&#xff0c;File > Setting 选择对应 CLL Interpreter&#xff0c;如果没有操…

GitHub登录收不到邮箱验证码

由于长时间没有登录GitHub&#xff0c;浏览器可能清除了相应的cookie信息&#xff0c;所以需要对应绑定邮箱进行验证&#xff0c;但因为邮箱长时间没有收到验证码&#xff0c;所以给到以下一种可能解决的方法&#xff1a; 需要输入验证码进行验证 我们可以打开QQ邮箱&#xff0…

java的深入探究JVM之类加载与双亲委派机制

前言 前面学习了虚拟机的内存结构、对象的分配和创建&#xff0c;但对象所对应的类是怎么加载到虚拟机中来的呢&#xff1f;加载过程中需要做些什么&#xff1f;什么是双亲委派机制以及为什么要打破双亲委派机制&#xff1f; 类的生命周期 类的生命周期包含了如上的7个阶段&a…