sql专题 之 where和join on

文章目录

  • 前言
  • where
    • 介绍
    • 使用
      • 过滤结果集
      • 关联两个表
  • 连接
    • 外连接
    • 内连接
    • 自然连接
  • 使用inner join和直接使用where关联两个表的区别
  • 总结

前言

从数据库查询数据时,一张表不足以查询到我们想要的数据,更多的时候我们需要联表查询。

联表查询我们一般会使用连接,如inner join 、left join、right join 和 outer join等,但是个别时候也会使用where,接下来我们了解一下join on和where的区别

  • 我们创建两个表,student和class(忽略数据的多少啊,仅做举例使用)
    在这里插入图片描述

在这里插入图片描述

where

介绍

WHERE 是 SQL 中的一个关键字,用于在查询(如 SELECT、UPDATE 或 DELETE)中指定条件,以过滤出符合特定标准的数据。

  • WHERE 子句可以显著提高查询的效率,因为它限制了数据库处理的数据量。

使用

过滤结果集

  • 条件运算符 和 逻辑运算法的使用

    这里不多说了,不清楚的可以移步这里 →sql专题 之 常用命令

  • where和having的区别

    WHERE 子句只能指定行的条件,而不能指定组的条件
    HAVING 子句可以使用聚合函数,它用来指定组的条件

关联两个表

  • 查询所有的学生的信息包括其班主任名称

    select * FROM student,class WHERE student.class_id = class.id
    

    在这里插入图片描述

    相信这是大多数同学们第一次联表查询老师教的方法。
    通过关联student表中的class_id 和 class表中的id,我们获取了所有的信息。
    要知道from后的“student,class”功能可以说跟inner join一模一样。

  • where也能实现,为什么还有join on呢?

    虽然仅通过where关键字也可以进行联表查询,但是在sql中,还是需要各司其职比较好。毕竟where的定位是过滤筛选结果集。

    where拿手的是筛选,咱就别贪多嚼不烂了,联表查询还是交给join把~

连接

连接花样就多了,有外连接、内连接 和 自然连接

外连接

不仅包含符合连接条件的行,还会包括左表(左连接)、右表(右连接)或两个表中的所有数据行(全外连接)

  • 左连接

    左表为主表,左表中所有记录都会出现在结果集中,如果该行的字段在右表中没有匹配上,那么右表对应的字段以null填充

    select * FROM student left join class on student.class_id = class.id
    

    在这里插入图片描述

    left join 以左边的student表为基准,显示了表中没有class_id的数据,并以null填充。
    这样的好处是:不漏掉student表中任何一个数据

  • 右连接

    右表为主表,右表中所有记录都会出现在结果集中,如果该行的字段在左表中没有匹配上,那么左表对应的字段以null填充

    select * FROM student right join class on student.class_id = class.id
    

    在这里插入图片描述

    right join 以右边的class表为基准,id为4的班级没有学生信息录入,那扔以null填充
    坚决不漏掉class表中任意一个数据

内连接

只连接匹配的行。
即只有条件的交叉连接,会根据某个条件筛选出符合条件的记录。不符合条件的记录不会出现在结果集中

select * FROM student inner join class on student.class_id = class.id

在这里插入图片描述

看,就取这俩表的交集,谁也不特殊照顾~~

自然连接

自然连接是一种特殊的等值连接,它基于两个或多个表之间的共同字段自动进行连接。自然连接会自动选择那些在两个表中具有相同名称和兼容数据类型的字段作为连接条件

  • 两个表没有相同的字段

    select * from student NATURAL JOIN class
    

    如我们上边的表,两个表的字段没有相同的,那么结果就是一个笛卡尔积。运行结果同
    “select * from student cross join class”

  • 两个表有相同的字段

    我们对student表增加一个列“teacher”。
    在这里插入图片描述

    select * from student NATURAL JOIN class
    

    在这里插入图片描述

    这里特意试了一个小陷阱,会发现,在查询结果中,teacher列只出现了一列。说明仅仅是按照字段一模一样来匹配的。

在实际应用中,自然连接的使用相对较少,因为它可能不够灵活,并且可能导致意外的结果。通常,更推荐使用显式的JOIN操作符和ON子句来指定连接条件,这样可以更精确地控制连接行为。

使用inner join和直接使用where关联两个表的区别

  • 实现原理
    • INNER JOIN‌

      使用INNER JOIN时,连接条件放在ON子句中,这是一种显式连接。
      这种方式通过哈希表进行连接比较,效率较高‌。

    • WHERE子句

      使用WHERE子句进行连接时,连接条件放在WHERE子句中,这是一种隐式连接。
      这种方式先生成笛卡尔积,然后再进行过滤,效率较低‌。

  • 性能差异
    • INNER JOIN

      使用哈希表进行连接比较,其时间复杂度为O(LogN),效率较高。

    • WHERE子句‌

      由于先生成笛卡尔积再进行过滤,其时间复杂度为O(N^2),因此效率较低‌。

  • 使用场景
    • INNER JOIN‌

      适用于需要高效连接查询的场景
      特别是在连接条件较为复杂或需要结合多个连接条件时

    • WHERE子句‌

      适用于连接条件较为简单,且不需要显式连接操作的场景
      虽然效率较低,但在某些简单查询中仍然可以使用‌

总结

选择使用join on还是where取决于查询的具体需求和表的连接类型。

在内部连接中,‌join on和where的作用相似,‌可以互换使用。‌但在非内部连接中,‌尤其是使用left join on等连接类型时,‌on用于定义表之间的连接条件,‌而where则用于进一步筛选结果集中的记录。‌

总的来说,联表以后还是用连接查询吧😏😏😏

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

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

相关文章

LeetCode 热题100之 动态规划1

对于动态规划的问题,解题步骤有以下几部(总结为动态规划五部曲:参考代码随想录动态规划 确定dp数组以及下标的含义;确定递推公式;dp数组如何初始化;确定遍历顺序;举例推导dp数组 下面的解题思路分析都将从…

python可视化将多张图整合到一起(画布)

这周有点事忙着,没时间重温刚结束的Mathurcup数学建模,这两天也是再看了下,论文还是赶紧挺烂的,但比国赛又有进步(说起国赛又不得不抱怨了,基本其余省份都发了,但江西......哎)。哎&…

MFC图形函数学习07——画扇形函数

绘制扇形函数是MFC中绘图的基本函数,它绘制的仍是由椭圆弧与椭圆中心连线构成的椭圆扇形,特例是由圆弧与圆心连线构成的圆扇形。 一、绘制扇形函数 原型:BOOL Pie(int x1,int y1,int x2,int y2,int x3,int y3,int x4,int y4); …

vue 依赖注入(Provide、Inject )和混入(mixins)

Prop 逐级透传问题​ 通常情况下,当我们需要从父组件向子组件传递数据时,会使用 props。想象一下这样的结构:有一些多层级嵌套的组件,形成了一棵巨大的组件树,而某个深层的子组件需要一个较远的祖先组件中的部分数据。…

手机上用什么方法可以切换ip

手机上用什么方法可以切换IP?在某些特定情境下,用户可能需要切换手机的IP地址,以满足网络安全、隐私保护或绕过地域限制等需求。下面以华为手机为例,将详细介绍手机IP地址切换的几种方法,帮助用户轻松实现这一目标。 一…

一个强大的Stable Diffusion comfyUI 工作流,能实现写真自由、各种风格融合、面部特征一致性等等

今天,我们将向您介绍一款非常实用的工具——Stable Diffusion comfyUI工作流。这款工作流基于Stable Diffusion技术,旨在为您提供一键式生成图像的便捷体验。无论您是AI绘画的新手还是专业人士,这个工作流都能为您带来极大的便利。 在这个教…

外泌体相关基因肝癌临床模型预测——2-3分纯生信文章复现——6.外泌体基因功能注释(二)

内容如下: 1.外泌体和肝癌TCGA数据下载 2.数据格式整理 3.差异表达基因筛选 4.预后相关外泌体基因确定 5.拷贝数变异及突变图谱 6.外泌体基因功能注释 7.LASSO回归筛选外泌体预后模型 8.预后模型验证 9.预后模型鲁棒性分析 10.独立预后因素分析及与临床的相关性分析…

【Homework】【1--4】Learning resources for DQ Robotics in MATLAB

Learning resources for DQ Robotics in MATLAB Lesson 1 代码 % Step 2: Define the real numbers a1 and a2 a1 123; a2 321;% Step 3: Calculate and display a3 a1 a2 a3 a1 a2; disp([a3 (a1 a2) , num2str(a3)])% Step 4: Calculate and display a3 a1 * a2 a3…

linux命令详解,存储管理相关

存储管理 一、内存使用量,free free 命令是一个用于显示系统中物理内存(RAM)和交换空间(swap)使用情况的工具 free -m free -m -s 5参数 -b 功能: 以字节(bytes)为单位显示内存使用情况。说…

推荐一款功能强大的视频修复软件:Apeaksoft Video Fixer

Apeaksoft Video Fixer是一款功能强大的视频修复软件,专门用于修复损坏、不可播放、卡顿、画面失真、黑屏等视频问题。只需提供一个准确且有效的样本视频作为参考,该软件就能将受损视频修复到与样本视频相同的质量。该软件目前支持MP4、MOV、3GP等格式的…

Redis如何保证数据不丢失(可靠性)

本文主要以学习为主,详细参考:微信公众平台 Redis 保证数据不丢失的主要手段有两个: 持久化 多机部署 我们分别来看它们两的具体实现细节。 1.Redis 持久化 持久化是指将数据从内存中存储到持久化存储介质中(如硬盘&#xf…

第三十九章 基于VueCli自定义创建项目

目录 1. 选择创建模式 2. 选择需要的功能 3. 选择历史模式还是哈希模式 ​4.CSS预处理器 5. 选择ESLint规则 6. 开始创建项目 ​7. 自定义项目最终结构 1. 选择创建模式 输入创建的项目名,创建项目: 这里选择自定义模式: 2. 选择需要…

【Vue3】基础语法案例

图片点击轮播 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><title>图片轮播</title> </head><body><div id"app"><h3>{{ number }}</h3><!-- 通过模板字…

【大数据学习 | kafka高级部分】kafka的kraft集群

首先我们分析一下zookeeper在kafka中的作用 zookeeper可以实现controller的选举&#xff0c;并且记录topic和partition的元数据信息&#xff0c;帮助多个broker同步数据信息。 在新版本中的kraft模式中可以这个管理和选举可以用kafka自己完成&#xff0c;而不再依赖zookeeper。…

生物发酵装备在制药工业中的应用与发展前景

在现代制药工业中&#xff0c;发酵技术扮演着越来越重要的角色。发酵设备&#xff0c;作为这一技术的核心&#xff0c;不仅促进了抗生素、疫苗和生物药物的生产&#xff0c;还为酶的生物合成提供了必要的条件。 发酵技术是指人们利用微生物的发酵作用&#xff0c;通过一系列的…

HCIP快速生成树 RSTP

STP&#xff08;Spanning Tree Protocol&#xff0c;生成树协议&#xff09;和RSTP&#xff08;Rapid Spanning Tree Protocol&#xff0c;快速生成树协议&#xff09;都是用于在局域网中消除环路的网络协议。 STP&#xff08;生成树协议&#xff09; 基本概念&#xff1a; ST…

Excel 无法打开文件

Excel 无法打开文件 ‘新建 Microsoft Excel 工作表.xlsx",因为 文件格式或文件扩展名无效。请确定文件未损坏&#xff0c;并且文件扩展名与文件的格式匹配。 原因是卸载WPS之后&#xff0c;注册表未修改过来。 重新下载WPS&#xff0c;新建&#xff0c;xls工作表&#x…

【计算机网络】网络框架

一、网络协议和分层 1.理解协议 什么是协议&#xff1f;实际上就是约定。如果用计算机语言进行表达&#xff0c;那就是计算机协议。 2.理解分层 分层是软件设计方面的优势&#xff08;低耦合&#xff09;&#xff1b;每一层都要解决特定的问题 TCP/IP四层模型和OSI七层模型…

DPPE-N3中叠氮基团使得DPPE-N3能够与含有炔基的材料在铜离子的催化下发生点击化学反应,生成稳定的1,2,3-三唑环结构,2252461-33-7

一、基本信息 英文名称&#xff1a;DPPE-N3&#xff0c;DPPE-Azide 中文名称&#xff1a;DPPE-叠氮 CAS号&#xff1a;2252461-33-7 分子式&#xff1a;C43H83N4O9P 分子量&#xff1a;831.13 供应商&#xff1a;陕西新研博美生物科技 结构式&#xff1a; 二、结构特点…

算法学习第一弹——C++基础

早上好啊&#xff0c;大佬们。来看看咱们这回学点啥&#xff0c;在前不久刚出完C语言写的PTA中L1的题目&#xff0c;想必大家都不过瘾&#xff0c;感觉那些题都不过如此&#xff0c;所以&#xff0c;为了我们能更好的去处理更难的题目&#xff0c;小白兔决定奋发图强&#xff0…