⑧【MySQL】数据库查询:内连接、外连接、自连接、子查询、多表查询

在这里插入图片描述

个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~
个人主页:.29.的博客
学习社区:进去逛一逛~

在这里插入图片描述

内连接、外连接、自连接、子查询、多表查询

  • ⑧MySQL数据库查询
    • 1. 多表关系
    • 2. 多表查询
      • 🚀内连接 —— INNER JOIN
      • 🚀左外连接 —— LEFT OUTER JOIN
      • 🚀右外连接 —— RIGHT OUTER JOIN
      • 🚀自连接 —— JOIN
      • 🚀联合查询 —— UNION、UNION ALL
      • 🚀子查询(嵌套查询)


⑧MySQL数据库查询


1. 多表关系

多表关系

  • 一对一 :在任意一方加入外键,关联另一方的主键,并设置外键为唯一(UNIQUE)。
  • 一对多(多对一) :在的一方建立外键,指向的一方的主键。
  • 多对多 :建立第三张表作为中间表,中间表至少包含两个外键,分别关联双方主键



2. 多表查询

多表查询

  • 在多张表中查询数据。
  • 笛卡尔积:两个集合,集合A 与 集合B中元素的所有组合情况,在多表查询时需要使用WHERE关键字JOIN ON关键字消除笛卡尔积。

🚀内连接 —— INNER JOIN

连接查询 —— 内连接

  • 内连接:

    • ①隐式内连接

      • SELECT 字段列表 FROM1,2 WHERE 连接条件...;
        
    • ②显示内连接

      • SELECT 字段列表 FROM1 [INNER] JOIN2 ON 连接条件...;
        
  • == 内连接查询的是两张表交集的部分 ==

  • 在这里插入图片描述

    • -- 演示:
      
      -- 查询员工姓名,以及关联的部门名称(隐式内连接)
      -- 表:员工表emp、部门表dept
      SELECT emp.name,dept.name 
      FROM emp,dept 
      WHERE emp.dept_id = dept.id;
      
      -- 查询员工姓名,以及关联的部门名称(显示内连接)
      -- 表:员工表emp、部门表dept
      SELECT emp.name,dept.name 
      FROM emp INNER JOIN dept ON emp.dept_id = dept.id;
      
      



🚀左外连接 —— LEFT OUTER JOIN

连接查询 —— 左外连接

  • 外连接 —— 左外连接:

    • 查询表1所有数据,包含表1和表2交集部分的数据。

      • SELECT 字段列表 FROM1 LEFT [OUTER] JOIN2 ON 连接条件...;
        
    • -- 演示:
      
      -- 查询emp表所有数据,以及对应部门信息(dept表数据)
      -- 左外连接实现
      SELECT emp.*,dept.name 
      FROM emp LEFT JOIN dept 
      ON emp.`dept_id` = dept.`id`;
      



🚀右外连接 —— RIGHT OUTER JOIN

连接查询 —— 右外连接

  • 外连接 —— 右外连接:

    • 查询表2所有数据,包含表1和表2交集部分的数据。

      • SELECT 字段列表 FROM1 RIGHT [OUTER] JOIN2 ON 连接条件...;
        
  • -- 演示:
    
    -- 查询emp表所有数据,以及对应部门信息(dept表数据)
    -- 右外连接实现
    SELECT emp.*,dept.name 
    FROM dept RIGHT JOIN emp 
    ON emp.`dept_id` = dept.`id`;
    



🚀自连接 —— JOIN

连接查询 —— 自连接

  • 自连接:

    • ①自连接查询,可以是内连接查询,也可以是外连接查询

      • SELECT 字段列表 FROM1 别名A JOIN1 别名B ON 连接条件...;
        
    • -- 演示
      
      -- 查询emp表员工 及其 所属领导的名字
      -- 使用内连接
      SELECT e1.`name` 员工,e2.`name` 领导
      FROM emp e1 JOIN emp e2 ON e1.`managerid` = e2.`id`;
      
      -- 查询emp表员工 及其 所属领导的名字,如果员工没有领导,也需要查询出来
      -- 使用外连接
      SELECT e1.`name` 员工,e2.`name` 领导
      FROM emp e1 LEFT JOIN emp e2 ON e1.`managerid` = e2.`id`;
      



🚀联合查询 —— UNION、UNION ALL

联合查询

  • UNION查询就是把多次查询的结果合并,行程新的结果集

    • -- 使用UNION,对结果去重
      -- 使用UNION ALL,不对结果去重
      -- 要求联合的多个查询字段列表的 类型与数量 需要保持一致
      SELECT 字段列表 FROM 表A ...
      UNION [ALL]
      SELECT 字段列表 FROM 表B ...;
      
  • -- 演示
    
    -- 查询薪资低于5000 以及 年龄大于50的员工
    -- 使用UNION,对结果去重
    -- 使用UNION ALL,不对结果去重
    SELECT * FROM emp WHERE emp.`salary` < 5000
    UNION
    SELECT * FROM emp WHERE emp.`age` > 50;
    



🚀子查询(嵌套查询)

子查询

  • 子查询:SQL语句中嵌套SELECT语句,称为嵌套查询,又称子查询

    • SELECT * FROM1 WHERE 字段1 = (SELECT 字段1 FROM2);
      
    • 子查询外部的语句可以是INSERT / UPDATE / DELETE / SELECT

  • 子查询分类(根据子查询结果不同):

    • 标量子查询(子查询结果为单个值)

      • -- 演示
        
        -- ①标量子查询
        -- 1.查询“销售部”的所有员工信息
        SELECT * FROM emp 
        WHERE dept_id = (SELECT id FROM dept WHERE dept.`name` = '销售部');
        
        -- 2.查询在“方东白”之后入职的员工信息
        SELECT * FROM emp 
        WHERE entrydate > (SELECT entrydate FROM emp  WHERE NAME = '方东白');
        
    • 列子查询(子查询结果为一列)

      • 常见操作符:

        • IN:在指定的集合范围之内,多选一
        • NOT IN不在指定的集合范围之内。
        • ANY:子查询返回列表内,有任意一个满足即可
        • SOME与ANY相同,使用SOME的地方都可以使用ANY。
        • ALL:子查询返回列表的所有值都必须满足
      • -- 演示
        
        -- ②列子查询
        -- 1. 查询“销售部” 和 “市场部” 所有员工信息
        SELECT * FROM emp
        WHERE emp.`dept_id` IN(SELECT id FROM dept WHERE NAME IN('销售部','市场部'));
        
        -- 2. 查询比财务部所有人工资都高的员工信息
        SELECT * FROM emp 
        WHERE emp.`salary` > 
        	ALL(SELECT salary FROM emp WHERE dept_id = 
        		(SELECT id FROM dept WHERE dept.`name` = '财务部'));
        		
        -- 3. 查询比财务部 任意一人 工资高的员工信息
        SELECT * FROM emp 
        WHERE emp.`salary` > 
        	ANY(SELECT salary FROM emp WHERE dept_id = 
        		(SELECT id FROM dept WHERE dept.`name` = '财务部'));
        
    • 行子查询(子查询结果为一行)

      • -- 演示
        
        -- ③行子查询
        -- 查询与“张无忌” 薪资 以及 直属领导 相同的员工信息
        SELECT * FROM emp 
        WHERE (salary,managerid) = 
        (SELECT salary,managerid FROM emp WHERE NAME = '张无忌');
        
    • 表子查询(子查询结果为多行多列)

      • -- 演示
        
        -- ④表子查询
        -- 查询入职时间是“2006-01-01”之后入职的员工信息及其部门信息
        SELECT e.*,dept.name 
        FROM(SELECT * FROM emp WHERE emp.`entrydate` > '2006-01-01') e
        LEFT JOIN dept ON e.dept_id = dept.`id`;
        




在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

蓝凌OA sysUiComponent 任意文件上传漏洞复现

0x01 产品简介 蓝凌核心产品EKP平台定位为新一代数字化生态OA平台&#xff0c;数字化向纵深发展&#xff0c;正加速构建产业互联网&#xff0c;对企业协作能力提出更高要求&#xff0c;蓝凌新一代生态型OA平台能够支撑办公数字化、管理智能化、应用平台化、组织生态化&#xff…

Azure 机器学习:使用 Azure 机器学习 CLI、SDK 和 REST API 训练模型

目录 环境准备克隆示例存储库 示例案例在云中训练1.连接到工作区PythonAzure CLIREST API 2. 创建用于训练的计算资源4. 提交训练作业PythonAzure CLIREST API 注册已训练的模型PythonAzure CLIREST API Azure 机器学习提供了多种提交 ML 训练作业的方法。 在本文中&#xff0c…

利用 Kubernetes 降本增效?EasyMR 基于 Kubernetes 部署的探索实践

Kubernetes 是用于编排容器化应用程序的云原生系统。最初由 Google 创建&#xff0c;如今由 Cloud Native Computing Foundation&#xff08;CNCF&#xff09;维护更新。 Kubernetes 是市面上最受欢迎的集群管理解决方案之一。它自动化容器化应用程序的部署、扩展和管理&#…

解决公网下,k8s calico master节点无法访问node节点创建的pod

目的&#xff1a;解决pod部署成功后&#xff0c;只能在node节点访问&#xff0c;而master节点无法访问 原因&#xff1a;集群搭建时&#xff0c;没有配置公网进行kubectl操作&#xff0c;从而导致系统默认node节点&#xff0c;使用内网IP加入k8s集群&#xff01;如下&#xff…

使用html2canvas转换table为图片时合并单元格rowspan失效,无边框显示问题解决(React实现)

最近使用 html2canvas导出Table表单为图片&#xff0c;但是转换出的图片被合并的单元格没有显示边框 查了原因是因为我为tr设置了背景色&#xff0c;然后td设置了rowspan&#xff0c;设置了rowspan的单元格就会出现边框不显示的问题。 解决方法就是取消tr的背景色&#xff0c;然…

抖音店铺所有商品数据接口(douyin.item_search_shop)

抖音店铺所有商品数据接口可以用于获取抖音店铺的所有商品数据&#xff0c;包括商品的标题、价格、库存、销量、评价等信息。通过该接口&#xff0c;开发者可以在自己的应用程序或网站中展示抖音店铺的商品信息&#xff0c;提升用户体验和购物决策效率。 此外&#xff0c;抖音…

苹果电脑杀毒软件cleanmymac2024

苹果电脑怎么杀毒&#xff1f;这个问题自从苹果电脑变得越来越普及&#xff0c;苹果电脑的安全性问题也逐渐成为我们关注的焦点。虽然苹果电脑的安全性相对较高&#xff0c;但仍然存在着一些潜在的威胁&#xff0c;比如流氓软件窥探隐私和恶意软件等。那么&#xff0c;苹果电脑…

这么好看的马面裙 ,女儿穿上不要太美了

红色小翻领&#xff0c;上身米白色金貂绒面料精细顺滑非常有质感 另外还有全手工定制的盘口裙子用的是仿宋代宋锦的织金面料 制作工艺非常复杂很重工的一件衣服 出门保证会被夸&#xff01;&#xff01;

叙永微公益:开展“活水计划-益童成长守护”周末陪伴活动

&#xff08;韩熙 林梅图/文&#xff09;2023年11月12日&#xff0c;叙永县微公益协会的志愿者们早早地驱车前往县内的孤困儿童家庭&#xff0c;与他们共同度过一个充实而温馨的周末。志愿者们不仅为孩子们带来了生活物资、零食、玩具等礼物&#xff0c;更重要的是&#xff0c;…

用Python制作截图小工具

Python编程语言允许我们执行各种任务&#xff0c;所有这些都是在简单模块和短小精悍的代码的帮助下完成的。在Python的帮助下进行屏幕截图就是这样一项任务。 Python为我们提供了许多模块&#xff0c;使我们能够执行不同的任务。有多种方法可以使用Python及其库进行屏幕截图。…

【linux】查看CPU的使用率

命令1&#xff1a;top top 总体系统信息 uptime&#xff1a;系统的运行时间和平均负载。tasks&#xff1a;当前运行的进程和线程数目。CPU&#xff1a;总体 CPU 使用率和各个核心的使用情况。内存&#xff08;Memory&#xff09;&#xff1a;总体内存使用情况、可用内存和缓存…

期望、方差

一、期望和方差的定义 随机变量(Random Variable) X 是一个映射&#xff0c;把随机试验的结果与实数建立起了一一对应的关系。而期望与方差是随机变量的两个重要的数字特征。 1. 期望(Expectation, or expected value) 期望是度量一个随机变量取值的集中位置或平均水平的最基…

Android开发:(AndroidStudio模拟器)如何将模拟器语言设置为中文 模拟器输入法更改为中文输入 键盘输入中文

文章目录 Android开发模拟器设置将模拟器语言设置为中文输入法中文的设置 Android开发模拟器设置 将模拟器语言设置为中文 第一步&#xff1a;打开模拟器后&#xff0c;上滑打开下面的设置图标。 第二步&#xff1a;找到 System (系统) &#xff0c;点击进入。 第三步&am…

6.docker运行mysql容器-理解容器数据卷

运行mysql容器-理解容器数据卷 1.什么是容器数据卷2.如何使用容器数据卷2.1 数据卷挂载命令2.2 容器数据卷的继承2.3 数据卷的读写权限2.4 容器数据卷的小实验&#xff08;加深理解&#xff09;2.4.1 启动挂载数据卷的centos容器2.4.2 启动后&#xff0c;在宿主机的data目录下会…

【仿真动画】ABB IRB 8700 机器人搬运(ruckig在线轨迹生成)动画欣赏

场景 动画 一、IRB 8700简介 二、动画脚本重点分析 2.1 sim.moveToPose 通过在两个 poses 之间执行插值&#xff0c;使用 Ruckig 在线轨迹生成器生成对象运动数据。该函数可以通过处理 4 个运动变量&#xff08;x、y、z 和两个姿势之间的角度&#xff09;或单个运动变量&#…

Transformer原理详解

前言&#xff1a;好久没有用了&#xff0c;我已经快忘记了自己还有一个CSDN账号了。 在某位不知名好友的提醒下&#xff0c;终于拾起来了&#xff0c;自己也从大二转变成了研二。 目前研究方向主要为&#xff1a;时间序列预测&#xff0c;自然语言处理&#xff0c;智慧医疗 欢迎…

git 指定时间代码统计

指定时间代码统计 用法 13 - 17 号 代码情况 近一周 git log --since2023-11-13 00:00:00 --until2023-11-17 23:00:00 --prettytformat: --numstat | awk { add $1; subs $2; loc $1 - $2 } END { printf "added lines: %s, removed lines: %s,total lines: %s\n&…

map和set的简易封装(纯代码)

RBTree.h #pragma once#include<iostream> #include<vector> using namespace std;enum colar { red,black };template<class T>//有效参数就一个 struct RBTreeNode {RBTreeNode(const T& data):_left(nullptr), _right(nullptr), _parent(nullptr)…

Vue bus事件总线的原理与使用

这里写自定义目录标题 一、 Vue Bus 总线原理二、Vue bus的使用1、创建总线&#xff1a; 在 Vue 应用中&#xff0c;可以创建一个 Vue 实例作为总线&#xff0c;用于管理事件。2、事件的发布与订阅&#xff1a; 组件通过订阅事件来监听总线上的消息&#xff0c;而其他组件则通过…

(免费)双相情感障碍筛查MDQ 在线测试双向情感障碍

MDQ用于筛查双相障碍&#xff0c;主要包含13个关于双相障碍症状的是非问题&#xff0c;当前测试采用的量表为2010年杨海晨博士翻译版。该量表为目前世界范围内最常用的双相障碍筛查量表&#xff0c;目前在精神科门诊最为常用的量表之一。 双向情感障碍筛查量表&#xff0c;也叫…