MySQL基础查询篇(4)-INNER JOIN和OUTER JOIN的区别

MySQL数据库中的INNER JOIN和OUTER JOIN是两种常用的连接查询操作,用于联合多张表中的数据。本文将详细介绍它们的区别和示例用法。

INNER JOIN

INNER JOIN(内连接)是连接查询中最常见的一种方式。它基于两个或多个表之间的共同字段(通常是主外键关系),将匹配的行合并为一行。它只返回两个表中共有的、符合连接条件的数据。

语法:

SELECT 列名 FROM 表1 INNER JOIN 表2 ON 表1.列 = 表2.列;

示例:

假设我们有两张表 usersorders,它们之间有一个共同的字段 user_id。我们希望获取所有有订单的用户的信息。

SELECT users.user_id, users.username, orders.order_id FROM users INNER JOIN orders ON users.user_id = orders.user_id;

上述语句将返回如下结果:

user_id | username | order_id --------|----------|--------- 1 | Alice | 101 2 | Bob | 102 3 | Charlie | 103

INNER JOIN仅返回同时在 usersorders 表中存在的用户数据。

OUTER JOIN

OUTER JOIN(外连接)是连接查询中的另一种方式。它可以返回两个表中共有的数据,以及一个表中没有匹配数据的行。

语法:

SELECT 列名 FROM 表1 [LEFT/RIGHT] JOIN 表2 ON 表1.列 = 表2.列;

OUTER JOIN又分为LEFT JOIN和RIGHT JOIN两种形式,分别是基于左表和右表返回结果。LEFT JOIN返回左表的所有行以及与右表匹配的行,而RIGHT JOIN返回右表的所有行以及与左表匹配的行。在MySQL中,可以使用LEFT OUTER JOINRIGHT OUTER JOIN关键字来替代LEFT JOINRIGHT JOIN

示例:

继续以上述 usersorders 表为例,我们希望获取所有用户的信息,包括没有订单的用户。

  • LEFT JOIN示例:

SELECT users.user_id, users.username, orders.order_id FROM users LEFT JOIN orders ON users.user_id = orders.user_id;

上述语句将返回如下结果:

user_id | username | order_id --------|----------|--------- 1 | Alice | 101 2 | Bob | 102 3 | Charlie | 103 4 | David | NULL

LEFT JOIN返回了左表 users 中的所有用户数据,同时也返回了在右表 orders 中有匹配的数据。由于用户David没有订单,所以 order_id 列显示为NULL。

  • RIGHT JOIN示例:

SELECT users.user_id, users.username, orders.order_id FROM users RIGHT JOIN orders ON users.user_id = orders.user_id;

上述语句将返回如下结果:

user_id | username | order_id --------|----------|--------- 1 | Alice | 101 2 | Bob | 102 3 | Charlie | 103 NULL | NULL | 104

RIGHT JOIN返回了右表 orders 中的所有订单数据,同时也返回了在左表 users 中有匹配的数据。由于没有与订单ID = 104匹配的用户,所以 user_idusername 列显示为NULL。

总结

INNER JOIN和OUTER JOIN是MySQL数据库中常用的连接查询操作。INNER JOIN基于两个或多个表之间的共同字段返回匹配的行,而OUTER JOIN除了返回匹配的行,还可以返回某个表中没有匹配的行。LEFT JOIN和RIGHT JOIN是OUTER JOIN的两种形式,分别基于左表和右表返回结果。根据实际需求,我们可以选择合适的连接方式进行数据查询。

希望本文能够帮助读者更好地理解INNER JOIN和OUTER JOIN,并在实际应用中能够正确使用它们。

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

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

相关文章

将`List<String>`转换为`List<Long>`

将List<String>转换为List<Long> 大家好&#xff0c;我是免费搭建查券返利机器人赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01;在Java中&#xff0c;将List<String>转换为List<Long>可以…

ChatGPT实战100例 - (15) 还不会写 Stable Diffusion (SD) 绘画提示词?没关系,ChatGPT帮你搞定

文章目录 ChatGPT实战100例 - (15) 还不会写 Stable Diffusion (SD) 绘画提示词&#xff1f;没关系&#xff0c;ChatGPT帮你搞定一、把场景描述转为镜头语言二、把镜头语言转换为Prompt三、把Prompt转换为图片 ChatGPT实战100例 - (15) 还不会写 Stable Diffusion (SD) 绘画提示…

速盾:免备案网站服务器接入cdn有哪些好处

接入CDN对免备案网站服务器来说有以下几个好处&#xff1a; 提高网站的访问速度&#xff1a;CDN会将网站的静态资源&#xff08;如图片、文档等&#xff09;缓存到离用户最近的节点服务器上&#xff0c;用户访问时可以从离他们最近的节点服务器获取资源&#xff0c;加快访问速度…

微端服务器都需要哪些配置?

微端服务器主要用于大型的网络游戏&#xff0c;可以会游戏用户提供流畅的网速&#xff0c;提高游戏用户的游戏体验感&#xff0c;那么微端服务器配置都有哪些呢&#xff1f; 微端服务器在配置方面是可以根据企业的需求来进行调整&#xff0c;微端服务器主要的核心组件有CPU&…

探秘Java 8 Lambda:简洁高效的集合操作

大家好&#xff0c;欢迎来到今天的播客节目&#xff01;我是你们的主持人&#xff0c;也是一位资深的软件开发者。在今天的节目中&#xff0c;我们将一起深入探讨Java 8中Lambda表达式的妙用&#xff0c;结合实例演示&#xff0c;帮助大家更好地理解并应用于实际的软件开发中。…

24.云原生ArgoCD高级之钩子

云原生专栏大纲 文章目录 Argo CD钩子如何定义钩子钩子删除策略 Argo CD钩子 Argo CD 是一个用于部署和管理 Kubernetes 应用程序的工具&#xff0c;它提供了一种声明式的方式来定义和自动化应用程序的部署过程。Argo CD 钩子&#xff08;Hooks&#xff09;是一种机制&#x…

历年地震数据,shp格式,含时间、位置、类型、震级等信息

基本信息. 数据名称: 历年地震数据 数据格式: Shp 数据时间: 2023年 数据几何类型: 点 数据坐标系: WGS84坐标系 数据来源&#xff1a;网络公开数据 数据字段&#xff1a; 序号字段名称字段说明1dzlx地震类型2zj震级3zysd震源深度&#xff08;米&#xff09;4jtwz…

HDMI2.1之eARC简介-Dolby Atmos和DTS:X

文章目录 eARC目的更大的带宽更高质量音频支持对象型音频与CEC&#xff08;Consumer Electronics Control&#xff09;的兼容性&#xff1a; 适应流媒体发展Dolby AtmosDTS:X高分辨率音频更高的音频位深度和采样率低延迟音频 对象型音频格式独立对象三维定位动态音场适应性和灵…

Web后端:CSRF攻击及应对方法

CSRF攻击是开发Web后端时需要重点解决的问题。 那么什么是CSRF攻击呢&#xff1f; CSRF跨站点请求伪造(Cross—Site Request Forgery)&#xff0c;其主要利用的是Cookie的一个弱点&#xff0c;就是Cookie 最初被设计成了允许在第三方网站发起的请求中携带&#xff1a; 关于Co…

RabbitMQ(一):最新版rabbitmq安装

目录 1 简介1.1特性及好处 2 安装2.1 Ubuntu22.04 apt安装最新rabbitmq1、一键部署2、验证3、RabbitMQWeb管理界面及授权操作4、添加远程用户5、一些常用命令 2.2 Docker安装RabbitMQ - Ubuntu22.041、安装docker2、启动rabbitmq 1 简介 RabbitMQ是一个开源的遵循AMQP协议实现…

【uniapp开发小程序】封装一个公共接口,每次点击不同页面时都会调用

在uni-app中封装一个公共接口&#xff0c;让每次点击不同页面时都会调用&#xff0c;您可以使用uni-app的全局混入&#xff08;mixin&#xff09;功能来实现 1.创建一个全局混入文件 mixin.js&#xff0c;并在其中定义一个公共方法&#xff1a; // mixin.js export default {…

设计模式之-适配器模式

在这个例子中&#xff0c;Adapter类继承自Target类&#xff0c;并在构造函数中接受一个Adaptee对象的指针。Adapter类的request方法会调用Adaptee对象的specificRequest方法。 在main函数中&#xff0c;我们创建了一个Adaptee对象和一个Adapter对象&#xff0c;并将Adaptee对象…

挑战杯 opencv 图像识别 指纹识别 - python

0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 基于机器视觉的指纹识别系统 &#x1f947;学长这里给一个题目综合评分(每项满分5分) 难度系数&#xff1a;3分工作量&#xff1a;3分创新点&#xff1a;4分 该项目较为新颖&#xff0c;适…

MagicVideo-V2:多阶段高保真视频生成框架

本项工作介绍了MagicVideo-V2&#xff0c;将文本到图像模型、视频运动生成器、参考图像embedding模块和帧内插模块集成到端到端的视频生成流程中。由于这些架构设计的好处&#xff0c;MagicVideo-V2能够生成具有极高保真度和流畅度的美观高分辨率视频。通过大规模用户评估&…

Zoho Projects与Jira:中国市场的理想替代品之争?

在软件开发生命周期中&#xff0c;项目管理一直是一个非常重要的环节。为了更好地协作、追踪项目的进程和管理任务&#xff0c;许多公司选择了Jira这款著名的项目管理工具&#xff0c;它是个非常强大的工具&#xff0c;但是作为一款纯国外产品&#xff0c;他可能不适合中国市场…

python统计分析——t分布

参考资料&#xff1a;用python动手学统计学 1、t统计量 t统计量的计算公式为&#xff1a; 其中&#xff0c;为样本均值&#xff0c;μ为总体均值&#xff0c;为实际样本的无偏标准差&#xff0c;N为样本容量。 t统计量的公式与标准化公式类似。t统计量可以理解为对样本均值…

css3动画的三种实现方式

目录 一、是什么二、实现方式transition 实现渐变动画transform 转变动画animation 实现自定义动画 三、总结参考文献 一、是什么 CSS动画&#xff08;CSS Animations&#xff09;是为层叠样式表建议的允许可扩展标记语言&#xff08;XML&#xff09;元素使用CSS的动画的模块 …

分布式session 笔记

概念 解决方案‘ 复制 session同步&#xff0c;让集群下的服务器进行session同步&#xff0c;一种传统的服务器集群session管理机制&#xff0c;常用于服务器不多的集群环境。<br /> 集群下&#xff0c;进行session同步的服务器的session数据是相同的&#xff0c;…

Redis面试题39

人工智能如何在交通领域发挥作用&#xff1f; 答&#xff1a;人工智能在交通领域发挥着重要的作用&#xff0c;可以改善交通效率和安全性。以下是一些人工智能在交通领域的应用示例&#xff1a; 交通流量优化&#xff1a;人工智能可以通过分析实时交通数据、监控摄像头图像和传…

【JavaScript 漫游】【007】数据类型转换

文章简介 本文为【JavaScript 漫游】专栏的第 007 篇文章&#xff0c;对 JS 数据类型转化语法进行了简记。 数据类型的转换指的是将 JS 的某一数据类型的值转换为 JS 的某一原始数据类型的值&#xff0c;也就是 number、string 和 boolean。 Number 方法强制转换为 number 类…