多表查询实训

前提

本篇博客,我将通过讲解例题的方式,带大家进一步掌握多表查询的使用规则和使用技巧

正文

前提

先建好表   表1 salgrade (薪资等级表) 表2 emp(员工信息表) 表3 dept(部门信息表),插入相关数据,我使用DataGrip 图像化界面工具,使用SQL语句,来操作。

表1 salgrade (薪资等级表)

grade 等级,losal 最低工资,hisal 最高工资

注意,表1 中添加主键约束 id 和 表1 dept_id  表2 id 是外键约束关系

表2 emp (员工信息表)

job 职位,salary  薪资 , entrydate 入职时间 managerid  直属领导 ,dept_id  工作位置编号 

由于我在建完表后,添加外检约束后,再插入数据。这一过程中,总是报违法外检约束错误,所以我将emp 表中的dept_id 全部设置为 null,后面再做更改

更改的语法:update  表名  set 字段=值  where条件;

表3 dept(部门信息表)

id 编号,name  工作地方名字

例题

1 查看员工的姓名,年龄,职位,部门信息(隐式内连接)

思路,该题涉及2 张表 emp(员工信息表) dept(部门信息表),同时还要使用隐式内连接

内连接:两张表取交集,也就是公共数据的部分 

我们知道,内连接分为两种 隐式内连接,显示内连接

隐式内连接语法:select  字段列表 from  表1, 表2  where 连接条件 and   其他条件;

连接条件:两张表中有联系的字段之间的组合比如通常是表1.id=表2.id。这样的形式。

显示内连接语法:select  字段列表  from 表1 (inner) join  表2  on  连接条件 where 条件;

代码如下

select  e.name ,e.age ,e.job,d.name   from emp e,dept d where e.dept_id =d.id ;

2 查询 年龄小于 30 岁的员工的姓名,年龄,职位,部门信息( 显示内连接)

思路:本题使用 emp表(员工信息表) dept表(部门信息表),同时要求使用显示内连接

内连接:两张表取交集,也就是公共数据的部分

显示内连接语法: select  字段列表  from 表1(inner)  join  表2  on  连接条件 where 条件;

代码如下

select  e.name ,e.age ,e.job,d.name   from emp e join dept d on  e.dept_id =d.id where e.age <30;

注意:如果出现重复数据,可以使用distinct 去重。

3 查询 所有年龄大于30 岁的员工,及其归属的部门,如果员工没有分配部门,也要显示

由于,现在的emp表中没有 员工,未分配部门,所以,我重新添加了数据

insert into emp values ( 9,'田明',42,'职员',26000,'2000-10-1',4,null),(10,'轩龙',39,'职员',20000,'2000-1-1',4,null );

思路:本题,使用 表1 emp ,表2 dept  。条件是年龄大30 ,同时还要查询没有分配的员工信息,所以使用外连接

外连接:两张表取任意一张表的全部,当然还包括他们公共的部分。

根据外连接查询的结果,分为左外连接,右外连接

左外连接语法:select  字段列表 from  表1 left  join  表2  on 连接条件 where 条件

提示:我们查询的是 left  左边的表 ,也就是表1.

右外连接语法:select  字段列表 from  表1 right  join  表2  on 连接条件 where 条件

提示:我们查询的是   表1 right  ,也就是表2 。

代码如下

select e. *,d2 .name from emp e left join day02.dept d2 on d2.id = e.dept_id where e.age >30;

4查询所有员工的工资等级

思路 :本题使用了 emp表, salgrade (薪资等级表)我们要查询员工的工资等级,就要知道这两张表的关系,如要知道工资等级,就是要通过比较 salgrade 中最小值和最大值,通过比较他们,来判断,是在哪一等级。

连接条件:emp.salary >=salgrade .losal and  emp.salary <=salgrade.hisal

代码如下

解法1 select e.name, s.grade from emp e,salgrade s where e.salary>=s.losal and e.salary<=s.hisal;

解法2  select e.name, s.grade from emp e,salgrade s where e.salary   between  s.losal and s.hisal;

5 查询策划部的所有员工的信息及工资等级

思路:本题,涉及三张表分别是 emp (员工信息表) ,salgrade (薪资等级表) ,dept(部门信息表)

emp(员工信息表)和dept(部门表)的连接条件:emp.dept_id=dept.id

emp和salgrade (薪资等级表)连接条件:emp.salary >=salgrade .losal emp.salary <=salgrade.hisal。同时我们要通过emp 表和 dept 表 ,得到策划部的员工信息,作为一张新的表。

代码如下

解法1 

select  e1.*, s.grade   from  (select e.*  from emp e ,dept d where e.dept_id=d.id and d.name='策划部') e1,salgrade s where e1.salary>=s.losal and e1.salary<=s.hisal;

解法2 

代码如下

select e.*,s.grade from emp e ,dept d ,salgrade s where e.dept_id=d.id and( e.salary between s.losal and s.hisal  )and d.name='策划部';

6 查询企划部 员工的平均工资

思路:本题 关联 emp表和dept表,通过内连接和外连接度可以。

内连接用法-隐式内连接

代码如下

select d.name, avg(e.salary) from emp e,dept d where e.dept_id=d.id and d.name='企划部';

外连接用法-左外连接

代码如下

select d.name, avg(e.salary) from emp  e   left join dept d on  e.dept_id=d.id where d.name='企划部';

7 查询工资比 刘敏高的员工信息

思路:本题 只涉及  emp表(员工信息表)

标量子查询

a 先求的员工刘敏的工资

代码如下:select e.salary from emp e where e.name='刘敏';

b 把求得刘敏工资作为条件,最终得到 比刘敏工资高的 员工信息

代码如下:select *from emp where salary>(select e.salary from emp e where e.name='刘敏');

8 查询比平均薪资高的员工信息

思路 :本题涉及emp表,标量子查询

标量子查询

a 查询平均薪资

代码如下:select avg(salary ) from emp ;

b 查询比平均薪资高的员工信息

代码如下:select *from emp where salary>(select avg(salary ) from emp );

9 查询低于本部门的平均工资的员工信息

错误思路,发现最后结果不对。因此仅供参考,

思路 本题涉及 emp 表 和dept表 连接条件: emp.dept_id=dept.id  同时 由于题目中,并没有指定具体是哪个部门,我们不妨先假设是企划部

a 查询本部门的平均薪资,我假定是 企划部

代码如下:

select avg(e.salary) from emp e,dept d where e.dept_id=d.id and d.name='企划部';

b 查询低于本部门的平均工资的员工信息

先假设是  低于企划部的员工信息 ,代码如下:

select *from  emp where salary< (select avg(e.salary) from emp e,dept d where e.dept_id=d.id and d.name='企划部');

通过代码可以发现,通过改变指定 部门就可以,所以这里使用了列子查询。

代码如下

select e1.*,((select avg(e.salary) from emp e,dept d where e.dept_id=d.id and (d.name in(select dept.name from dept )))) '该部门平均薪资' from emp e1 where salary< (select avg(e.salary) from emp e,dept d where e.dept_id=d.id and (d.name any(select dept.name from dept ))); 运行报错

正确解法

我同样是假设部门id=1 求平均薪资

代码如下:select  avg(e1.salary) from emp  e1  where e1.dept_id=1;

可以是dept_id =1 也可以是2 等等

select  avg(e1.salary) from emp  e1  where e1.dept_id=2;

从这可以看出 在emp表中 当你要得到 id=1 所属部门的平均薪资,你要将id=1 那一行的dept_id 的值传进去,才行。因此代码如下

select e2.*,((select  avg(e1.salary) from  emp e1 where e1.dept_id=e2.dept_id)) '平均薪资' from emp e2 where e2.salary<(select  avg(e1.salary) from  emp e1 where e1.dept_id=e2.dept_id);

10 查询所有部门的信息,并统计部门的员工人数

思路:本题中有emp表和dept ,其中emp表是作为子查询参与,并充当外层SQL语句的字段使用的

代码如下:select * ,(select count(* )from emp where dept_id=dept.id ) '人数' from dept ;

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

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

相关文章

docker-mysql主从复制

MySQL主从复制 安装docker和拉取镜像不再赘述 一.主服务器 1.新建主服务器容器-3307 &#xff08;这里设置的密码可能不生效&#xff0c;若未生效请看问题中的2&#xff09; docker run -p 3307:3306 --name mysql-master \ -v /mydata/mysql-master/log:/var/log/mysql \…

第三十七篇——麦克斯韦的妖:为什么要保持系统的开放性?

目录 一、背景介绍二、思路&方案三、过程1.思维导图2.文章中经典的句子理解3.学习之后对于投资市场的理解4.通过这篇文章结合我知道的东西我能想到什么&#xff1f; 四、总结五、升华 一、背景介绍 如果没有详细的学习这篇文章&#xff0c;我觉得我就是被麦克斯韦妖摆弄的…

[机缘参悟-200] - 对自然、人性、人生、人心、人际、企业、社会、宇宙全面系统的感悟 - 全图解

对自然、人性、人生、人心、人际、企业、社会、宇宙进行全面系统的感悟&#xff0c;是一个极其深邃且复杂的主题。以下是对这些领域的简要感悟&#xff1a; 自然&#xff1a; 自然是人类生存的根基&#xff0c;它充满了无尽的奥秘和美丽。自然界的平衡和循环规律&#xff0c;教…

算法设计与分析--近似算法内容整理

文章目录 P、NP、NP-hard 和 NPC多项式时间概念区分NP-hard 的证明例题 1 证明 T S P TSP TSP 问题是 N P − h a r d NP-hard NP−hard 问题 。例题 2 证明最大加权独立集问题是 N P − h a r d NP-hard NP−hard 问题。 扩展 NP-hard 问题3-SAT 问题TSP 旅行商问题 Load B…

AI大模型的制造业场景,一文读懂

导读 如何认识这一轮AI技术发展影响的深度和广度&#xff1f;如何判断这一轮AI技术变革的性质&#xff1f; AI大模型是通用人工智能发展的重要里程碑。中央会议关于人工智能发展提出三个第一次&#xff1a;第一次提出“通用人工智能”&#xff0c;第一次提出“产业智能化”&a…

武汉星起航:激发中国卖家潜力,亚马逊减免政策共筑电商辉煌

在全球化电子商务的浪潮中&#xff0c;亚马逊作为全球领先的电商平台&#xff0c;一直致力于为卖家提供卓越的服务和支持。特别是对于中国卖家而言&#xff0c;亚马逊的减免优惠政策无疑是一股强大的助力&#xff0c;帮助他们在不断发展的市场中脱颖而出&#xff0c;实现业务的…

设计模式 - Observer Pattern 观察者模式

文章目录 定义观察者模式的实现构成构成UML图 观察者模式的代码实现场景代码实现 总结优点缺点应用场景 其他设计模式文章&#xff1a; 定义 观察者模式是行为型模式的一种&#xff0c;它定义对象间的一种一对多的依赖关系&#xff0c;使得每当一个对象改变状态&#xff0c;它…

MathType7.6专业数学公式编辑器!与Word、PPT等常用软件无缝对接。

MathType&#xff0c;一款专业的数学公式编辑器&#xff0c;以其强大的功能和友好的用户界面&#xff0c;在科研、教学等领域广受欢迎。它支持丰富的数学符号和公式模板&#xff0c;满足不同用户的需求。同时&#xff0c;MathType还提供了多种输出格式&#xff0c;方便与其他文…

基于YOLOv9+pyside的安检仪x光危险物物品检测(有ui)

安全检查在公共场所确保人身安全的关键环节&#xff0c;不可或缺。X光安检机作为必要工具&#xff0c;在此过程中发挥着重要作用。然而&#xff0c;其依赖人工监控和判断成像的特性限制了其应用效能。本文以此为出发点&#xff0c;探索了基于Torch框架的YOLO算法在安检X光图像中…

《数据结构与算法基础 by王卓老师》学习笔记——类C语言有关操作补充

1.元素类型说明 2.数组定义 3.C语言的内存动态分配 4..C中的参数传递 5.传值方式 6.传地址方式 例子

【计算机网络】期末复习(2)

目录 第一章&#xff1a;概述 第二章&#xff1a;物理层 第三章&#xff1a;数据链路层 第四章&#xff1a;网络层 第五章&#xff1a;传输层 第一章&#xff1a;概述 三大类网络 &#xff08;1&#xff09;电信网络 &#xff08;2&#xff09;有线电视网络 &#xff0…

快速了解GPT-4o和GPT-4区别

GPT-4o简介 在5月14日的OpenAI举行春季发布会上&#xff0c;OpenAI在活动中发布了新旗舰模型“GPT-4o”&#xff01;据OpenAI首席技术官穆里穆拉蒂&#xff08;Muri Murati&#xff09;介绍&#xff0c;GPT-4o在继承GPT-4强大智能的同时&#xff0c;进一步提升了文本、图像及语…

JVM原理(四):JVM垃圾收集算法与分代收集理论

从如何判定消亡的角度出发&#xff0c;垃圾收集算法可以划分为“引用计数式垃圾收集”和“追踪式垃圾收集”两大类。 本文主要介绍的是追踪式垃圾收集。 1. 分代收集理论 当代垃圾收集器大多遵循“分代收集”的理论进行设计&#xff0c;它建立在两个假说之上&#xff1a; 弱分…

vue插槽的简单使用

默认插槽 1.在Category中创建插槽 <slot>默认值<slot/> 2.在App中使用 <Category tittle"美食"> <ul ><li v-for"(l,index) in foods" :key"index">{{l}}</li></ul> </Category> 3.运行后的…

【教学类65-04】20240625秘密花园涂色书04(通义万相)(图纸16:9,A4横板1张,一大168张纸168份)

背景需求 【教学类65-01】20240622秘密花园涂色书01&#xff08;通义万相&#xff09;&#xff08;A4横版2张&#xff0c;一大3小 38张纸76份&#xff09;-CSDN博客文章浏览阅读118次。【教学类65-01】20240622秘密花园涂色书01&#xff08;通义万相&#xff09;&#xff08;A…

操作系统-文件的物理结构(文件分配方式)

文章目录 总览文件块和磁盘块连续分配顺序访问直接访问&#xff08;随机访问&#xff09;为什么连续分配同时支持这两种访问模式&#xff1f; 链接分配隐式链接显示链接小结索引分配链接方案多层索引混合索引小结 总结 总览 文件数据存放在外存中 文件块和磁盘块 文件内通过逻…

万字长文详解数据结构:树 | 第6章 | Java版大话数据结构 | 二叉树 | 哈夫曼树 | 二叉树遍历 | 构造二叉树 | LeetCode练习

&#x1f4cc;本篇分享的大话数据结构中&#x1f384;树&#x1f384;这一章的知识点&#xff0c;在此基础上&#xff0c;增加了练习题帮助大家理解一些重要的概念✅&#xff1b;同时&#xff0c;由于原文使用的C语言代码&#xff0c;不利于学习Java语言的同学实践&#xff0c;…

Linux中使用网络文件系统NFS挂载远程目录,对远程文件的本地化操作

目录 一、NFS及其在linux系统中的挂载 1、NFS概述 2、NFS挂载及其作用 &#xff08;1&#xff09;资源共享 &#xff08;2&#xff09;简化数据管理 &#xff08;3&#xff09;提高数据可用性 &#xff08;4&#xff09;灵活性 &#xff08;5&#xff09;访问控制 &am…

web刷题记录(7)

[HDCTF 2023]SearchMaster 打开环境&#xff0c;首先的提示信息就是告诉我们&#xff0c;可以用post传参的方式来传入参数data 首先考虑的还是rce&#xff0c;但是这里发现&#xff0c;不管输入那种命令&#xff0c;它都会直接显示在中间的那一小行里面&#xff0c;而实际的命令…

工业自动化控制中心

目录 一 设计原型 二 后台源码 一 设计原型 二 后台源码 using System; using System.Threading; using System.Threading.Tasks; using System.Windows.Forms;namespace 工业自动化控制中心 {public partial class Form1 : Form{public Form1(){InitializeComponent();}pri…