Mysql-复合查询

实际开发中往往数据来自不同的表,所以需要多表查询。

1.笛卡尔积

通俗来讲就是两个表的每一列都组合一遍,也就是穷举法。 

穷举出来的数据表会有大量重复数据,而我们只需要加上一些限定条件就可以完成有效数据的筛选。 

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

2.自连接 

自连接是指在同一张表连接查询 

显示员工FORD的上级领导的编号和姓名(mgr是员工领导的编号--empno
  • 使用的子查询
select empno,ename from emp where emp .empno =( select mgr from emp where ename= 'FORD' );
  • 使用的多表查询 
-- 使用到表的别名
--from emp leader, emp worker ,给自己的表起别名,因为要先做笛卡尔积,所以别名可以先识别
select leader .empno ,leader .ename from emp leader, emp worker where leader .empno =
worker .mgr and worker .ename = 'FORD' ;

3. 内外连接

表的连接分为内连和外连。

3.1 内连接

内连接实际上就是利用 where 子句对两种表形成的笛卡儿积进行筛选,我们前面学习的查询都是内连接,也是在开发过程中使用的最多的连接查询。
语法:
select 字段 from 1 inner join 2 on 连接条件 and 其他条件;

显示SMITH的名字和部门名称

select ename, dname from EMP inner join DEPT on EMP .deptno =DEPT .deptno and
ename= 'SMITH' ;

3.2 外连接 

外连接分为左外连接和右外连接 

3.21 左外连接

如果联合查询,左侧的表完全显示我们就说是左外连接。 

语法:  

select 字段名 from 表名1 left join 表名2 on 连接条件 

查询所有学生的成绩,如果这个学生没有成绩,也要将学生的个人信息显示出来

-- 当左边表和右边表没有匹配时,也会显示左边表的数据
select * from stu left join exam on stu .id =exam .id ;

3.22 右外连接

如果联合查询,右侧的表完全显示我们就说是右外连接。  

语法:  

select 字段 from 表名1 right join 表名2 on 连接条件; 

stu表和exam表联合查询,把所有的成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来

select * from stu right join exam on stu.id=exam.id;  

4.子查询 

子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询 

返回一行记录的子查询  

  • 显示SMITH同一部门的员工 

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

4.1 多行子查询 

返回多行记录的子查询  

  • 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);

    4.2 在from子句中使用子查询

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

5.合并查询 

为了合并多个select的执行结果,可以使用集合操作符 unionunion all  

5.1 union 

该操作符用于取得两个结果集的并集。当使用该操作符时,会自动去掉结果集中的重复行。 

已知T1和T2的字段定义完全相同,T1有5条不同数据,T2有5条不同数据,其中T1有2条数据存在表T2中,使用UNION语句查询这些数据,要求重复数据不出现 

select * 
from T1
union
select *
from T2

5.2 union all 

该操作符用于取得两个结果集的并集。当使用该操作符时,不会去掉结果集中的重复行。 

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

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

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

相关文章

阿里巴巴java开发手册-编程规约

编程规约 命名风格常量定义代码格式OOP 规约日期时间集合处理并发处理控制语句注释规约前后端规约其他 命名风格 【强制】代码中的命名均不能以下划线或美元符号开始&#xff0c;也不能以下划线或美元符号结束。 反例&#xff1a;_name / name / n a m e / n a m e / n a m e…

腾讯云服务器怎么样好用吗?腾讯云服务器性能评测

近年来&#xff0c;腾讯云作为一家领先的云服务提供商&#xff0c;备受关注。尤其是最近两年&#xff0c;腾讯云在优惠活动上的力度非常大&#xff0c;被誉为良心云。其优惠政策吸引了越来越多的用户选择腾讯云作为他们的云服务提供商。 腾讯云双十一领9999代金券 https://111…

Python编程技巧 – 对象和类

Python编程技巧 – 对象和类 Python Programming Skills – Object and Class Python是一种面向对象的高级程序语言。 本文简要介绍用Python如何实现面向对象&#xff0c;对象和类的声明及使用&#xff0c;以及面向对象的特征&#xff0c;及其如何使用属性和方法的介绍&#x…

为什么我学了几天 STM32 感觉一脸茫然?

为什么我学了几天 STM32 感觉一脸茫然&#xff1f; 刷到过b站的zhihui君吧&#xff0c;去看他的回答&#xff0c;他的第一块开发板是arduino&#xff0c;这种级别的人物&#xff0c;在国内也是大神级了&#xff0c;最早学电子方向也是用的arduino。最近很多小伙伴找我&#xff…

wpf devexpress绑定grid到总计和分组统计

此主题描述了如何在gridcontrol中的视图模型和显示定义总计和分组统计 在视图模型中指定统计 1、创建 SummaryItemType 枚举你想要在GridControl中显示的统计类型&#xff1a; public enum SummaryItemType { Max, Count, None } 2、创建一个grid统计描述类 public class S…

从零开始:抖音酒店景区小程序开发指南

为了满足用户多样化的需求&#xff0c;开发一款抖音酒店景区小程序成为了业界的一个新兴趋势。在这篇文章中&#xff0c;我们将探讨如何开发一款引人注目的抖音风格的酒店景区小程序。 一、抖音风格的设计理念 在设计酒店景区小程序时&#xff0c;我们需要融入抖音的设计理念。…

Java对象、类、数据类型、变量类型

一、Java对象和类&#xff1a; 对象是类的一个实例&#xff0c;有状态和行为。类是一个模版&#xff0c;描述一类对象的行为和状态。对象的状态就是属性&#xff0c;行为通过方法体现。方法操作对象内部状态的改变&#xff0c;对象的相互调用也是通过方法来完成。 一个类可以包…

客户端性能优化实践

背景 双十一大促时&#xff0c;客户客服那边反馈商品信息加载卡顿&#xff0c;在不断有订单咨询时&#xff0c;甚至出现了商品信息一直处于加载状态的情况&#xff0c;显然&#xff0c;在这种高峰期接待客户时&#xff0c;是没法进行正常的接待工作的。 起初&#xff0c;页面一…

【代码随想录】算法训练计划24

回溯模板&#xff1a; 1、77. 组合 题目&#xff1a; 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。 你可以按 任何顺序 返回答案。 思路&#xff1a; 很经典的回溯&#xff0c;也是回溯中模板的经典应用&#xff0c;因而是回溯中的简单题…

观测云助力跨境电商大幅提高加载性能

话不多说&#xff0c;先上结果 什么是用户体验 用户体验基本包含访问网站的性能、可用性和正确性。通俗的讲&#xff0c;就是一把通过用户访问测量【设计者】意图的尺子。 用户体验的基本价值 如果正确实施了终端用户体验&#xff0c;可以第一时间发现&#xff0c;确认影响了…

python 对图像进行聚类分析

import cv2 import numpy as np from sklearn.cluster import KMeans import time# 中文路径读取 def cv_imread(filePath, cv2_falgcv2.COLOR_BGR2RGB): cv_img cv2.imdecode(np.fromfile(filePath, dtypenp.uint8), cv2_falg) return cv_img# 自定义装饰器计算时间 def…

【C++】泛型编程 ⑥ ( 类模板 | 类模板语法 | 代码示例 )

文章目录 一、类模板1、类模板引入2、声明类模板语法3、调用类模板语法 二、代码示例 - 类模板1、代码示例2、执行结果 一、类模板 1、类模板引入 类模板 与 函数模板 的 作用类似 , 当 多个类 功能相同 , 只是数据类型不同 , 此时可以 定义一个类模板 代替 定义多个类 ; 借助…