【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

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Java 正则表达式的使用实战案例

《Java正则表达式的使用实战案例》本文详细介绍了Java正则表达式的使用方法,涵盖语法细节、核心类方法、高级特性及实战案例,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、正则表达式语法详解1. 基础字符匹配2. 字符类([]定义)3. 量词(控制匹配次数)4. 边

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.