MySQL表的内连和外连

内连接

实际上我们在表的复合查询部分用的就是内连接,只不过语法不是很规范。

标准语法:

sql 复制代码
select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件;

如,显示SMITH的名字和部门名称:

之前的写法:

sql 复制代码
mysql> select ename,dname from emp,dept where emp.deptno=dept.deptno and ename='SMITH';
+-------+----------+
| ename | dname    |
+-------+----------+
| SMITH | RESEARCH |
+-------+----------+
1 row in set (0.00 sec)

标准写法:

sql 复制代码
mysql> select ename,dname from emp inner join dept on emp.deptno=dept.deptno where ename='SMITH';
+-------+----------+
| ename | dname    |
+-------+----------+
| SMITH | RESEARCH |
+-------+----------+
1 row in set (0.00 sec)

外连接

外连接又分为左外连接和右外连接。

左外连接

如果联合查询,左侧的表完全显示我们就说是左外连接。

语法:

sql 复制代码
select 字段名  from 表名1 left join 表名2 on 连接条件

示例:

我们先创建两个表:

sql 复制代码
create table stu (id int, name varchar(30)); -- 学生表
insert into stu values(1,'jack'),(2,'tom'),(3,'kity'),(4,'nono');
create table exam (id int, grade int); -- 成绩表
insert into exam values(1, 56),(2,76),(11, 8);

查询所有学生的成绩,如果这个学生没有成绩,也要将学生的个人信息显示出来:

如果使用普通的内连接:

右外连接

如果联合查询,右侧的表完全显示我们就说是右外连接。

语法:

sql 复制代码
select 字段 from 表名1 right join 表名2  on  连接条件;

示例:

  1. 对stu表和exam表联合查询,把所有的成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来
  2. 列出部门名称和这些部门的员工信息,同时列出没有员工的部门

OJ

做些简单OJ巩固下:

  1. 分数排名
sql 复制代码
SELECT
  S.score,
  COUNT(DISTINCT T.score) AS 'rank'
FROM
  Scores S
  INNER JOIN Scores T ON S.score <= T.score
GROUP BY
  S.id,
  S.score
ORDER BY
  S.score DESC;
  1. 换座位
sql 复制代码
SELECT 
    t1.id,
    t2.student
FROM Seat t1
JOIN Seat t2 
    ON t1.id - 1 + 2 * MOD(t1.id, 2) = t2.id
    OR (t1.id = (SELECT MAX(id) FROM Seat) 
        AND t2.id = t1.id 
        AND MOD(t1.id, 2) = 1)
ORDER BY t1.id;
相关推荐
恋猫de小郭2 分钟前
Swift 6.3 正式发布支持 Android ,它能在跨平台发挥什么优势?
android·前端·flutter
一只会跑会跳会发疯的猴子4 分钟前
php操作ssl,亲测可用
android·php·ssl
时光追逐者27 分钟前
一款免费、简单、高效的在线数据库设计工具
数据库·mysql·oracle·sql server
another heaven28 分钟前
【软考 2026 最新版 NoSQL 数据库全分类】
数据库·nosql
满天星830357729 分钟前
【MySQL】表的操作
linux·服务器·数据库·mysql
yashuk33 分钟前
Ubuntu 系统下安装 Nginx
数据库·nginx·ubuntu
F1FJJ39 分钟前
VS Code 里管理 PostgreSQL,有哪些选择?主流扩展横向对比
网络·数据库·postgresql·容器
Bdygsl1 小时前
MySQL(8)—— 事务
数据库·mysql
IvorySQL1 小时前
直播回顾| PostgreSQL 18.3 x IvorySQL 5.3:开启 AI 数据库新纪元
数据库·postgresql·开源
编程之升级打怪1 小时前
数据库的实时同步和异步同步
数据库