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

mysql中的内连接与外连接

在MySQL中,内连接和外连接是用于从多个表中检索数据的两种不同的连接方式。

  1. 内连接(INNER JOIN)
    内连接返回两个表之间匹配的行。它只返回两个表中共同匹配的行,如果在一个表中没有匹配到对应的行,则不会显示在结果中。

    语法如下:

    SELECT columns
    FROM table1
    INNER JOIN table2 ON table1.column = table2.column;
    

    例如,假设我们有两个表:studentsgrades,它们通过学生ID进行关联。下面的查询将返回两个表中匹配的学生及其成绩:

    SELECT students.name, grades.grade
    FROM students
    INNER JOIN grades ON students.student_id = grades.student_id;
    
  2. 外连接(OUTER JOIN)
    外连接允许返回匹配的行以及未匹配的行。MySQL支持左外连接(LEFT JOIN)、右外连接(RIGHT JOIN)和全外连接(FULL JOIN)。

    • 左外连接(LEFT JOIN):返回左表中的所有行,以及右表中与左表中行匹配的行。如果右表中没有匹配的行,则会在结果中显示 NULL 值。

      语法如下:

      SELECT columns
      FROM table1
      LEFT JOIN table2 ON table1.column = table2.column;
      
    • 右外连接(RIGHT JOIN):与左外连接类似,但是返回右表中的所有行,以及左表中与右表中行匹配的行。

      语法如下:

      SELECT columns
      FROM table1
      RIGHT JOIN table2 ON table1.column = table2.column;
      
    • 全外连接(FULL JOIN):返回两个表中的所有行,并且对于没有匹配的行,将会使用 NULL 值填充。

      MySQL并不直接支持FULL JOIN,但可以通过UNION ALL和LEFT JOIN、RIGHT JOIN的组合来实现。

    例如,下面的查询将返回所有学生,以及他们的成绩(如果有的话):

    SELECT students.name, grades.grade
    FROM students
    LEFT JOIN grades ON students.student_id = grades.student_id;
    
http://www.lryc.cn/news/357593.html

相关文章:

  • 0基础认识C语言(理论+实操 2)
  • ChatGPT的基本原理是什么?又该如何提高其准确性?
  • 云计算OpenStack基础
  • [10] CUDA程序性能的提升 与 流
  • TH方程学习(1)
  • 【九十七】【算法分析与设计】图论,迷宫,1207. 大臣的旅费,走出迷宫,石油采集,after与迷宫,逃离迷宫,3205. 最优配餐,路径之谜
  • 【Tools】SpringBoot工程中,对于时间属性从后端返回到前端的格式问题
  • 算法训练营day35
  • 代码随想录-Day23
  • 基于Visual Studio版本的AI编程助手
  • 04-Vue:ref获取页面节点--很简单
  • CBK-D2-安全与架构工程.md
  • Windows驱动开发系列文章一
  • java项目之人事系统源码(springboot+vue+mysql)
  • I/O '24|学习资源焕新,技术灵感升级
  • 前端应用开发实验:表单控件绑定
  • [双指针] --- 快乐数 盛最多水的容器
  • 操作系统 - 输入/输出(I/O)管理
  • 代码随想录算法训练营第22天(py)| 二叉树 | 669. 修剪二叉搜索树、108.将有序数组转换为二叉搜索树、538.把二叉搜索树转换为累加树
  • 使用C语言实现学生信息管理系统
  • 上下文视觉提示实现zero-shot分割检测及多visual-prompt改造
  • WebGL学习(一)渲染关系
  • 人生建议:向猫学习
  • 软件架构设计属性之三:结构性属性浅析
  • JAVA:多线程常见的面试题和答案
  • 短信平台-平台群发短信
  • C++:类和对象
  • JavaScript条件语句与逻辑判断:解锁代码逻辑的奥秘【含代码示例】
  • sparksql自定义函数
  • 新人开发新系统,旧人维护旧系统