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;
相关推荐
jiayou641 小时前
KingbaseES 实战:审计追踪配置与运维实践
数据库
随风飘的云2 小时前
mysql的innodb引擎对可重复读做了那些优化,可以避免幻读
mysql
二流小码农3 小时前
鸿蒙开发:上传一张参考图片便可实现页面功能
android·ios·harmonyos
鹏程十八少3 小时前
4.Android 30分钟手写一个简单版shadow, 从零理解shadow插件化零反射插件化原理
android·前端·面试
Kapaseker4 小时前
一杯美式搞定 Kotlin 空安全
android·kotlin
三少爷的鞋4 小时前
Android 协程时代,Handler 应该退休了吗?
android
NineData13 小时前
NineData 迁移评估功能正式上线
数据库·dba
火柴就是我18 小时前
让我们实现一个更好看的内部阴影按钮
android·flutter
NineData18 小时前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师20 小时前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql