mysql中的内连接与外连接

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

  1. 内连接(INNER JOIN)

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

    语法如下:

    sql 复制代码
    SELECT columns
    FROM table1
    INNER JOIN table2 ON table1.column = table2.column;

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

    sql 复制代码
    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 值。

      语法如下:

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

      语法如下:

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

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

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

    sql 复制代码
    SELECT students.name, grades.grade
    FROM students
    LEFT JOIN grades ON students.student_id = grades.student_id;
相关推荐
亭台烟雨中17 分钟前
SQL优化简单思路
数据库·sql
老华带你飞2 小时前
畅阅读小程序|畅阅读系统|基于java的畅阅读系统小程序设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·小程序·毕设·畅阅读系统小程序
Codeking__3 小时前
mysql基础——库与表的操作
数据库·mysql
_苏沐3 小时前
cte功能oracle与pg执行模式对比
数据库·oracle
silver98864 小时前
再谈golang的sql链接dsn
mysql·golang
qq_508823408 小时前
金融数据库--3Baostock
数据库·金融
悦数图数据库8 小时前
图技术重塑金融未来:悦数图数据库如何驱动行业创新与风控变革
数据库·金融
九河云8 小时前
华为云 GaussDB:金融级高可用数据库,为核心业务保驾护航
网络·数据库·科技·金融·华为云·gaussdb
老华带你飞8 小时前
租房平台|租房管理平台小程序系统|基于java的租房系统 设计与实现(源码+数据库+文档)
java·数据库·小程序·vue·论文·毕设·租房系统管理平台
ouou061711 小时前
企业级NoSql数据库Redis集群
数据库·redis·nosql