【MySQL进阶之路】oracle 9i的经典测试雇员信息表案例——多表查询

本文主要是介绍【MySQL进阶之路】oracle 9i的经典测试雇员信息表案例——多表查询,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

引言

笛卡尔积

自连接

子查询

单行子查询

多行子查询

多列子查询

在from子句中使用子查询

合并查询


个人主页:东洛的克莱斯韦克-CSDN博客

引言

在数据库的实际开发中,多表查询是一项非常基础且重要的技能。它允许你将来自不同表的数据结合起来,以满足复杂的业务需求。多表查询主要通过几种方式实现,包括但不限于连接(JOIN)、子查询(Subquery)、联合(UNION)等

本文会配合案例,深入探讨多表查询

准备工作,创建一个雇员信息表(来自oracle 9i的经典测试表) EMP员工表 DEPT部门表 SALGRADE工资等级表 如何显示每个部门的平均工资和最高工资

员工表emp

部门表dept

工资表salgrade

笛卡尔积

笛卡尔积(Cartesian product)是数学和数据库理论中的一个重要概念,尤其是在关系数据库管理系统(RDBMS)中。当两个或多个表进行连接(join)但没有指定任何连接条件时,就会生成笛卡尔积。

在数据库术语中,如果表A有M行,表B有N行,那么A和B的笛卡尔积将是一个包含M*N行的新表,这个新表中的每一行都是通过将A中的每一行与B中的每一行进行组合而得到的。结果表中的列是原始表列的简单并集。

显示部门号为10的部门名,员工名和工资

select ename, sal,dname from EMP, DEPT where EMP.deptno=DEPT.deptno and
DEPT.deptno = 10;

显示各个员工的姓名,工资,及工资级别

select ename, sal, grade from EMP, SALGRADE where EMP.sal between losal and
hisal;

自连接

将一张表看作两个或多个逻辑表,并通过它们之间的共同字段进行连接。这种操作允许我们在同一张表内比较或组合不同行的数据。

如果不指定连接条件,自连接将生成一个笛卡尔积,即表中每一行与其他所有行的组合。这通常不是我们想要的结果,因为它会产生大量无关的数据。

显示员工FORD的上级领导的编号和姓名(mgr是员工领导的编号--empno)

select leader.empno,leader.ename from emp leader, emp worker where
leader.empno = worker.mgr and worker.ename='FORD';

子查询

子查询(Subquery)是嵌入在其他SQL语句(通常是SELECT、INSERT、UPDATE或DELETE语句)中的SELECT语句。这种查询允许我们将一个查询的结果用作另一个查询的条件或数据源。子查询也被称为嵌套查询或内部查询,因为它们被嵌入在另一个查询(外部查询)中。

单行子查询

显示SMITH同一部门的员工

select * from EMP WHERE deptno = (select deptno from EMP where
ename='smith');

多行子查询

in关键字;查询和10号部门的工作岗位相同的雇员的名字,岗位,工资,部门号,但是不包含10自 己的

select ename,job,sal,deptno from emp where job in (select distinct job from
emp where deptno=10) and deptno<>10;

all关键字;显示工资比部门30的所有员工的工资高的员工的姓名、工资和部门号

select ename, sal, deptno from EMP where sal > all(select sal from EMP where
deptno=30);

any关键字;显示工资比部门30的任意员工的工资高的员工的姓名、工资和部门号(包含自己部门 的员工)

select ename, sal, deptno from EMP where sal > any(select sal from EMP where
deptno=30);

多列子查询

查询和SMITH的部门和岗位完全相同的所有雇员,不含SMITH本人

select ename from EMP where (deptno, job)=(select deptno, job from EMP
where ename='SMITH') and ename <> 'SMITH';

在from子句中使用子查询

子查询语句出现在from子句中。这里要用到数据查询的技巧,把一个子查询当做一个临时表使用。

显示每个高于自己部门平均工资的员工的姓名、部门、工资、平均工资

select ename, deptno, sal, format(asal,2) from EMP,
(select avg(sal) asal, deptno dt from EMP group by deptno) tmp
where EMP.sal > tmp.asal and EMP.deptno=tmp.dt;

查找每个部门工资最高的人的姓名、工资、部门、最高工资

select EMP.ename, EMP.sal, EMP.deptno, ms from EMP,
(select max(sal) ms, deptno from EMP group by deptno) tmp
where EMP.deptno=tmp.deptno and EMP.sal=tmp.ms;

显示每个部门的信息(部门名,编号,地址)和人员数量

select DEPT.deptno, dname, mycnt, loc from DEPT,
(select count(*) mycnt, deptno from EMP group by deptno) tmp
where DEPT.deptno=tmp.deptno;

合并查询

在SQL中,当我们需要合并多个SELECT语句的执行结果时,可以使用集合操作符UNIONUNION ALL。这两个操作符都允许我们将两个或多个SELECT语句的结果集合并成一个结果集,但它们之间有一些关键的区别。

UNION操作符用于合并两个或多个SELECT语句的结果集,并自动去除重复的行。这意呀着,如果两个结果集中有完全相同的行(基于所有选择的列的值),那么这些行在最终的结果集中只会出现一次。

UNION不同,UNION ALL操作符用于合并两个或多个SELECT语句的结果集,但它不会去除重复的行。如果两个结果集中有相同的行,那么这些行在最终的结果集中都会出现。

将工资大于2500或职位是MANAGER的人找出来

select ename, sal, job from EMP where sal>2500 unionselect ename, sal, job from EMP where job='MANAGER';

将工资大于25000或职位是MANAGER的人找出来

select ename, sal, job from EMP where sal>2500 union allselect ename, sal, job from EMP where job='MANAGER';

这篇关于【MySQL进阶之路】oracle 9i的经典测试雇员信息表案例——多表查询的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL zip安装包配置教程

《MySQLzip安装包配置教程》这篇文章详细介绍了如何使用zip安装包在Windows11上安装MySQL8.0,包括下载、解压、配置环境变量、初始化数据库、安装服务以及更改密码等步骤,感兴趣的朋... 目录mysql zip安装包配置教程1、下载zip安装包:2、安装2.1 解压zip包到安装目录2.2

MySQL安装时initializing database失败的问题解决

《MySQL安装时initializingdatabase失败的问题解决》本文主要介绍了MySQL安装时initializingdatabase失败的问题解决,文中通过图文介绍的非常详细,对大家的学... 目录问题页面:解决方法:问题页面:解决方法:1.勾选红框中的选项:2.将下图红框中全部改为英

Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)

《Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)》本文介绍了如何使用Python和Selenium结合ddddocr库实现图片验证码的识别和点击功能,感兴趣的朋友一起看... 目录1.获取图片2.目标识别3.背景坐标识别3.1 ddddocr3.2 打码平台4.坐标点击5.图

MySQL 中的服务器配置和状态详解(MySQL Server Configuration and Status)

《MySQL中的服务器配置和状态详解(MySQLServerConfigurationandStatus)》MySQL服务器配置和状态设置包括服务器选项、系统变量和状态变量三个方面,可以通过... 目录mysql 之服务器配置和状态1 MySQL 架构和性能优化1.1 服务器配置和状态1.1.1 服务器选项

SpringBoot中整合RabbitMQ(测试+部署上线最新完整)的过程

《SpringBoot中整合RabbitMQ(测试+部署上线最新完整)的过程》本文详细介绍了如何在虚拟机和宝塔面板中安装RabbitMQ,并使用Java代码实现消息的发送和接收,通过异步通讯,可以优化... 目录一、RabbitMQ安装二、启动RabbitMQ三、javascript编写Java代码1、引入

MySQL8.0设置redo缓存大小的实现

《MySQL8.0设置redo缓存大小的实现》本文主要在MySQL8.0.30及之后版本中使用innodb_redo_log_capacity参数在线更改redo缓存文件大小,下面就来介绍一下,具有一... mysql 8.0.30及之后版本可以使用innodb_redo_log_capacity参数来更改

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形