多表查询(JOIN)

1.连接查询

通过连接运算符可以实现多个表查询。分为内连接、外连接、交叉连接
注:连接运算是由一个笛卡尔积运算和一个选取运算构成的。首先用笛卡尔积完成对两个数据集合的乘运算,然后对生成的结果集合进行选取运算

2.示例表如下

student表
student表
score表
score表

3.内连接

把两个表中数据对应的数据查询出来,内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分为三种:

(1)等值连接
在连接条件中使用等于号“=”运算符比较被连接列的列值,其查询结果中列出被连接表中的所有列,包括其中的重复列

SELECT *
FROM student INNER JOIN score
ON student.id = score.id

在这里插入图片描述

(2)自然连接
在连接条件中使用等于“=”运算符比较被连接列的列值,但它使用选择列表指出查询结果集合中所包括的列,并删除连接表中的重复列
注:自然连接仅适用于那些具有相同名称和数据类型的列。如果两个表中的列名称或数据类型不匹配,自然连接将无法执行

-- NATURAL JOIN无ON语句
SELECT *
FROM student NATURAL JOIN score

在这里插入图片描述

(3)不等值连接
在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些运算符包括>、>=、<=、<、!>、!<和<>

4.外连接

以某个表为基础把对应数据查询出来,返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外连接时)、右表(右外连接时)或两个表(全外连接)中的所有行

(1)左外连接

SELECT *
FROM student LEFT OUTER JOIN score
ON student.id = score.id

在这里插入图片描述

(2)右外连接

SELECT *
FROM student RIGHT OUTER JOIN score
ON student.id = score.id

在这里插入图片描述

(3)全外连接

SELECT *
FROM student FULL OUTER JOIN score
ON student.id = score.id

在这里插入图片描述

5.交叉连接

交叉连接不带ON语句,返回被连接的两个表所有行的笛卡尔积

-- CROSS JOIN无ON语句
SELECT *
FROM student CROSS JOIN score

在这里插入图片描述

  • 10
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码届艺术家

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值