这篇文章主要给大家介绍了关于数据库中JOIN的用法,文中通过示例代码介绍的非常详细,对大家学习或者使用数据库具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

前言

本章主要介绍数据库中Join的的用法,也是我们在使用数据库时非常基础的一个知识点。本次会介绍数据库中的 inner join、 left join、 right join 的用法以及它们之间的区别。 文章如有错误还请大家及时指出~

以下都是采用mysql数据库

Join

相信大家在学习数据库的使用时,都有使用过Join,对数据库中的两张或两张以上表进行连接操作。

Join 分为:

    内连接(inner join) 外连接(outer join)

其中外连接分为:

    左外连接(left outer join) 右外连接(right outer join) 全外连接(full outer join)

说明:

1.其中外连接的“OUTER”关键字可以省略不写。 2.内连接用于返回连接条件的记录;而外连接则是内连接的扩展,它不仅会连接条件的记录,而且还会返回不连接条件的记录。

笛卡尔积

在我们进行多表联合查询的时候会出现的一种情况——笛卡尔积现象

我们以下面两张表举例:

学生表(Student)

IDStudentNameStudentClassID1小明12小红23小兰34小吕25小梓1

班级表(Class)

ClassIDClassName1软件一班2软件二班3软件三班

当我们进行查询操作的时候:

select * from Student,Class;

就会出现上面的情况,也就是笛卡尔现象,表Student中有5条记录,表Class中有3条记录,那么对于表Student而言有5种选择,对于表Class来说有3种选择。所以一共有 5 * 3 = 15种选择了,也就是笛卡尔积。

内连接——inner join

内连接查询返回条件的所有记录,默认情况下没有指定任何连接则为内连接。 例如:查询xx学生在xx班级 沿用上面的数据表

select stu.StudentName,cl.ClassName from Student stu inner join Class cl on stu.StudentClassID=cl.ClassID;

查询结果

左外连接——left join

左外连接查询不仅返回条件的所有记录,而且还会返回不连接条件的连接操作符左边表的其他行。 我们在原Student 表中新增学生: 

例如: 查询xx学生在xx班级 沿用上面的数据表

select stu.StudentName,cl.ClassName from Student stu left join Class cl on stu.StudentClassID=cl.ClassID;

查询结果

右外连接——right join
右外连接查询不仅返回条件的所有记录,而且还会返回不连接条件的连接操作符右边表的其他行。 我们在原Class表中新增班级:

软件四班

 例如: 查询xx学生在xx班级 沿用上面的数据表

select stu.StudentName,cl.ClassName from Student stu right join Class cl on stu.StudentClassID=cl.ClassID;

查询结果

全连接——full join

全连接查询不仅返回条件的所有记录,而且还会返回不连接条件的其他行。

注:mysql默认不支持full join。

这里我们就不做介绍了。

文末

本章节主要介绍了Iterable与Iterator之间的区别与联系,以及其他方面的小知识点,也是面试过程中会出现的内容点。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对爱安网的支持。

最新资讯
揭秘国产5G基带芯片:紫光展锐如何越过珠穆朗玛峰?

揭秘国产5G基带芯片:紫

5G基带芯片的制造难点在于,首先需要先进制程的支持;此外
面板大厂备战折叠屏:京东方绵阳柔性产线明年满产

面板大厂备战折叠屏:京

今年上半年,可折叠手机火了。它背后的屏幕技术正是柔性
惠普第三财季营收146亿美元 净利润同比增34%

惠普第三财季营收146

惠普第三财季净营收为146亿美元,比去年同期的146亿美元
美团点评股价重回发行价:临近上市1周年 市值超4000亿港元

美团点评股价重回发行

在美团点评将迎来上市一周年,及明日要公布半年报之际,美
消息称大众汽车CEO对收购特斯拉股份感兴趣

消息称大众汽车CEO对

路透社今日援引德国《经理人》杂志的报道称,大众汽车CE
蔚来9月底前裁员1200人 造车新势力如何过冬?

蔚来9月底前裁员1200

8月22日,蔚来汽车创始人李斌对全体员工下发内部信,称9月
最新文章
一篇文章带你了解数据库中JOIN的用法

一篇文章带你了解数据

这篇文章主要给大家介绍了关于数据库中JOIN的用法,文中
SQL语句优化的一些必会指南

SQL语句优化的一些必

这篇文章主要给大家介绍了关于SQL语句优化的相关资料,
SQL行转列、列转行的简单实现

SQL行转列、列转行的

这篇文章主要给大家介绍了关于SQL行转列、列转行的简
建立在Tablestore的Wifi设备监管系统架构实现

建立在Tablestore的Wi

一般大公司会有许多园区,园区内会有不同部门的同事在一
你真的知道怎么优化SQL吗

你真的知道怎么优化SQ

这篇文章主要给大家介绍了关于优化SQL的相关资料,文中
如何让Birt报表脚本数据源变得既简单又强大

如何让Birt报表脚本数

这篇文章主要介绍了如何让Birt报表脚本数据源变得既简