当前位置: 首页 > news >正文

mysql 的内连接、左连接、右连接有什么区别?

在MySQL中,内连接、左连接和右连接是三种常见的连接类型,它们用于通过共享一个或多个字段的值,将两个或多个表组合在一起进行查询。以下是这三种连接类型的详细区别:

一、内连接(INNER JOIN)

  1. 定义:内连接是最常见的连接类型,它返回两个表中匹配的行。内连接只返回两个表中满足连接条件的行,如果两个表中的任何一方没有匹配的行,则不会返回该行。
  2. 语法
    SELECT columns  
    FROM table1  
    INNER JOIN table2  
    ON table1.column = table2.column;

  3. 示例:假设有两个表,employees和departments,分别包含员工信息和部门信息。可以使用内连接来检索员工所属部门的信息。
    SELECT employees.employee_id, employees.first_name, employees.last_name, departments.department_name  
    FROM employees  
    INNER JOIN departments  
    ON employees.department_id = departments.department_id;

  4. 应用场景:内连接适用于需要同时从两个表中检索相关数据的场景,例如检索员工及其所属部门的信息。

    二、左连接(LEFT JOIN)

  5. 定义:左连接返回左表(左侧表达式)中的所有行,以及与右表匹配的行。如果右表中没有匹配的行,那么返回的结果集中将包含NULL值。
  6. 语法
    SELECT columns  
    FROM left_table  
    LEFT JOIN right_table  
    ON left_table.column = right_table.column;

  7. 示例:假设有两个表,customers和orders,分别包含顾客信息和订单信息。可以使用左连接来检索所有顾客及其订单信息,如果某个顾客没有订单,则订单相关的字段将显示NULL值。

三、右连接(RIGHT JOIN)

在实际应用中,应根据具体需求选择合适的连接类型来查询数据。

  1. 定义:右连接返回右表(右侧表达式)中的所有行,以及与左表匹配的行。如果左表中没有匹配的行,那么返回的结果集中将包含NULL值。
  2. 语法
    SELECT columns  
    FROM left_table  
    RIGHT JOIN right_table  
    ON left_table.column = right_table.column;

  3. 示例:同样以customers和orders两个表为例,可以使用右连接来检索所有订单及其对应的顾客信息,如果某个订单没有对应的顾客(在实际情况中这种情况较少见,但为了示例的完整性而提及),则顾客相关的字段将显示NULL值。
    SELECT customers.customer_id, customers.customer_name, orders.order_date  
    FROM customers  
    RIGHT JOIN orders  
    ON customers.customer_id = orders.customer_id;

  4. 应用场景:右连接适用于需要检索右表中的所有记录以及与之相关联的左表中的记录的场景,例如检索所有订单及其对应的顾客信息。
  5. 四、总结

  6. 匹配行返回:内连接只返回两个表中满足连接条件的匹配行;左连接返回左表中的所有行以及右表中匹配的行,未匹配的行返回NULL值;右连接返回右表中的所有行以及左表中匹配的行,未匹配的行返回NULL值。
  7. 使用场景:内连接适用于需要同时从两个表中检索相关数据的场景;左连接适用于需要检索左表中的所有记录以及与之相关联的右表中的记录的场景;右连接则适用于需要检索右表中的所有记录以及与之相关联的左表中的记录的场景。
http://www.lryc.cn/news/473734.html

相关文章:

  • update-alternatives(选择工具)
  • php解密,sg11解密-sg15解密 如何由sourceGuardian11-sourceGuardian15加密(sg11加密~sg15加密)的源码
  • b站小土堆PyTorch视频学习笔记(二)
  • Linux的压缩及其解压命令
  • GXYCTF2019:gakki
  • 顺序表(C 语言)
  • 一:时序数据库-Influx应用
  • Word文档丢失抢救方法:15 个 Word 文档恢复工具
  • 关于自动驾驶等级相关知识
  • Java中跳转结构
  • CNN-Attention分类预测 | Matlab实现多特征分类预测
  • [java][基础]JSP
  • 《测绘学报》
  • 代码随想录之链表刷题总结
  • Python爬虫的“京东大冒险”:揭秘商品类目信息
  • 双目视觉标定——1原理与实践
  • 【设计模式系列】代理模式(八)
  • 微服务架构设计的初次尝试——基于以太坊智能合约 + NestJS 微服务的游戏社区与任务市场系统:架构设计
  • “北斗+实景三维”,助力全域社会治理
  • #渗透测试#SRC漏洞挖掘# 信息收集-常见端口及谷歌语法
  • 如何使用java雪花算法在分布式环境中生成唯一ID?
  • 【php常用公共函数】php获取指定时间段相差几小时,几分钟,几秒
  • 图文深入介绍Oracle DB link(一)
  • Uniswap/v2-core使用及其交易流程
  • clickhouse运维篇(二):多机器手动部署ck集群
  • OpenCV视觉分析之目标跟踪(7)目标跟踪器类TrackerVit的使用
  • Java 实现 RESTful 风格的 Web 服务详解
  • 18.网工入门篇--------今天介绍下广域网技术
  • 鸿蒙原生应用开发及部署:首选华为云,开启HarmonyOS NEXT App新纪元
  • Spring JdbcTemplate详解