news 2026/6/23 15:43:16

MySQL 知识点复习- 6. inner/right/left join

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL 知识点复习- 6. inner/right/left join

JOIN按照功能大致分为三类:

INNER JOIN(内连接):获取两个表中字段匹配关系的记录。

LEFT JOIN (左连接): 获取左表所有记录,即使右表没有匹配的记录。

RIGHT JOIN(右连接):用于 获取右表的所有记录,即使左表没有对应匹配的记录。

1. INNER JOIN:

语法:

SELECT column1, column2,....

FROM table1

INNER JOIN table2 on table1.column_name = table2.column_name;

1.简单的 INNER JOIN:

SELECT orders.order_id, customers.customer_name FROM orders INNER JOIN customers ON orders.customer_id = customers.customer_id;

2. 使用表别名:

SELECT o.order_id, c.customer_name FROM orders AS o INNER JOIN customers AS c ON o.customer_id = c.customer_id;

3. 多表 INNER JOIN:

SELECT orders.order_id, customers.customer_name, products.product_name FROM orders INNER JOIN customers ON orders.customer_id = customers.customer_id INNER JOIN order_items ON orders.order_id = order_items.order_id INNER JOIN products ON order_items.product_id = products.product_id;

以上 SQL 语句涉及了 orders、customers、order_items 和 products 四个表的连接。它选择了订单 ID、客户名称和产品名称,连接了这些表的关联列。

4. 使用 WHERE 子句进行过滤:

SELECT orders.order_id, customers.customer_name FROM orders INNER JOIN customers ON orders.customer_id = customers.customer_id WHERE orders.order_date >= '2023-01-01';

以上 SQL 语句在 INNER JOIN 后使用 WHERE 子句,过滤了订单日期在 '2023-01-01' 及以后的订单。

2. LEFT JOIN

LEFT JOIN 返回左表的所有行,并包括右表中匹配的行,如果右表中没有匹配的行,将返回 NULL 值,以下是 LEFT JOIN 语句的基本语法:

SELECT column1, column2, ... FROM table1 LEFT JOIN table2 ON table1.column_name = table2.column_name;

1. 简单的 LEFT JOIN:

SELECT customers.customer_id, customers.customer_name, orders.order_id FROM customers LEFT JOIN orders ON customers.customer_id = orders.customer_id;

以上 SQL 语句将选择客户表中的客户 ID 和客户名称,并包括左表 customers 中的所有行。

3. RIGHT JOIN

RIGHT JOIN 返回右表的所有行,并包括左表中匹配的行,如果左表中没有匹配的行,将返回 NULL 值,以下是 RIGHT JOIN 语句的基本语法::

SELECT column1, column2, ... FROM table1 RIGHT JOIN table2 ON table1.column_name = table2.column_name;

以下是一个简单的 RIGHT JOIN 实例:

SELECT customers.customer_id, orders.order_id FROM customers RIGHT JOIN orders ON customers.customer_id = orders.customer_id;

以上 SQL 语句将选择右表 orders 中的所有订单 ID,并包括左表 customers 中匹配的客户 ID。如果在 customers 表中没有匹配的客户 ID,相关列将显示为 NULL。

在开发过程中中,RIGHT JOIN 并不经常使用,因为它可以用 LEFT JOIN 和表的顺序交换来实现相同的效果。例如,上面的查询可以通过使用 LEFT JOIN 改写为:

SELECT customers.customer_id, orders.order_id FROM orders LEFT JOIN customers ON orders.customer_id = customers.customer_id;

以上 SQL 语句返回相同的结果,因为 LEFT JOIN 与 RIGHT JOIN 是对称的。在实际使用中,你可以根据个人偏好或组织规范选择使用哪种形式。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 15:40:41

对比传统方法:AI如何更高效解决wsappx资源问题

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个AI驱动的wsappx优化对比工具,功能包括:1. 传统优化方法模拟;2. AI优化方法实现;3. 实时性能对比展示;4. 历史数据…

作者头像 李华
网站建设 2026/6/22 19:27:00

Netty入门指南:5分钟搭建你的第一个网络应用

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个交互式新手教程,引导用户完成第一个Netty项目。要求:1) 分步骤讲解Netty核心概念;2) 提供可修改的示例代码(如Echo服务器);3…

作者头像 李华
网站建设 2026/6/23 10:26:48

欧拉筛选法求质数的算法解析

正常的埃氏筛选法是定义一个bool型的数组,把所有数组的元素初始化为1.表示初始阶段所有数都是质数。开始对数组进行筛选,把所有含有2和2的倍数的所有数筛选掉。在把所有含有3和3的倍数的所有数筛选掉,再把含有5和5的倍数的所有数筛选掉.一直筛…

作者头像 李华
网站建设 2026/6/23 13:39:22

15、探索 Red Hat Linux 的实用功能与娱乐体验

探索 Red Hat Linux 的实用功能与娱乐体验 设备同步与实用程序 在进行设备同步时,设备端口可能是 /dev/ttyS0 或 /dev/ttyS1 。不用怕麻烦,通过逐个尝试,就能找到正确的端口。通常情况下,无需担心速度设置,除非你的计算机非常老旧,否则默认值就足够了。以下是同步的…

作者头像 李华
网站建设 2026/6/23 13:41:39

基于Simulink仿真的电动汽车模型构建与参数初始化研究

电动汽车模型Simulink仿真 仿真中搭建了电动汽车模型,包括电池模型、电机模型、动力传输模型以及汽车模型,仿真中的参数由C文件在Matlab中进行初始化设置。咱们今天来唠唠怎么在Simulink里搭电动汽车模型。这玩意儿说复杂吧其实拆开了也就四大块&#xf…

作者头像 李华
网站建设 2026/6/23 13:41:32

JavaScript数组push方法:小白也能懂的入门指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个交互式学习JS push方法的教程应用:1. 分步骤讲解push方法的基本语法;2. 提供可编辑的代码示例,实时显示运行结果;3. 包含5个…

作者头像 李华