SQL基础【十五、join、Inner join、Left join、Right join、Full join】

简介: SQL基础【十五、join、Inner join、Left join、Right join、Full join】

Join


数据库中的表可以通过键将彼此联系起来,主键是一个列,在这个列中的每一行的值都是唯一的,在表中,每个主键的值都是唯一的,这样就可以在不重复每个表中的所有数据的情况下,把表间的数据交叉捆绑在一起。


以下为表user和表Room的数据


微信图片_20220110160951.png  微信图片_20220110160956.png



1:引用两个表


找出在Room of boy相关联的用户信息


Select u.user_name,u.user_age,r.room_name from user as u,room as r


Where u.room_id = r.room_id and r.room_name='room of boy'


微信图片_20220110161023.png


2:使用关键字join来连接两张表


Select u.user_name,u.user_age,r.room_name


from user as u


join room as r


on u.room_id = r.room_id and r.room_name='room of boy'


微信图片_20220110161040.png

Inner join


Inner join 与 join 用法一致


Select u.user_name,u.user_age,r.room_name


from user as u


inner join room as r


on u.room_id = r.room_id and r.room_name='room of boy'


微信图片_20220110161056.png


Left join

注意:左连接以左边的表为主体,也就是说会列出左边的表中的所有的数据,无论它是否满足条件。


1:user在左边


Select u.user_name,u.user_age,r.room_name


from user as u


Left join room as r


on u.room_id = r.room_id and r.room_name='room of boy'


微信图片_20220110161114.png


2:Room在左边


Select u.user_name,u.user_age,r.room_name


From room as r


Left join user as u


on u.room_id = r.room_id and r.room_name='room of boy'


微信图片_20220110161132.png


Right join


注意:左连接以右边的表为主体,也就是说会列出左边的表中的所有的数据,无论它是否满足条件。


1:Room在右边


Select u.user_name,u.user_age,r.room_name


from user as u


Right join room as r


on u.room_id = r.room_id and r.room_name='room of boy'


微信图片_20220110161148.png


2:user在右边


Select u.user_name,u.user_age,r.room_name


from  room as r


Right join user as u


on u.room_id = r.room_id and r.room_name='room of boy'


微信图片_20220110161208.png


Full join


1:user在左边


Select * from user Full join room


微信图片_20220110161225.png


2:Room在左边


Select * From room full join user


微信图片_20220110161241.png

注意:SQL错误码1054表示没有找到对应的字段名;错误码1064表示用户输入的SQL语句有语法错误

 

希望能对大家有所帮助。

相关文章
|
1月前
|
SQL 关系型数据库 MySQL
7种SQL Join语句
7种SQL Join语句
18 1
|
4月前
|
SQL
sql 各种join 对比
sql 各种join 对比
30 0
|
1月前
|
SQL 缓存 算法
SQL 语句不要过多的 join
SQL 语句不要过多的 join
18 1
|
3月前
|
SQL Java 数据库连接
这个问题是由于Flink在执行SQL语句时,无法找到合适的表工厂来处理JOIN操作。
【1月更文挑战第17天】【1月更文挑战第85篇】这个问题是由于Flink在执行SQL语句时,无法找到合适的表工厂来处理JOIN操作。
23 8
|
16天前
|
SQL 人工智能 算法
【SQL server】玩转SQL server数据库:第二章 关系数据库
【SQL server】玩转SQL server数据库:第二章 关系数据库
52 10
|
1月前
|
SQL 数据库 数据安全/隐私保护
Sql Server数据库Sa密码如何修改
Sql Server数据库Sa密码如何修改
|
26天前
|
SQL
启动mysq异常The server quit without updating PID file [FAILED]sql/data/***.pi根本解决方案
启动mysq异常The server quit without updating PID file [FAILED]sql/data/***.pi根本解决方案
17 0
|
16天前
|
SQL 算法 数据库
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
88 6
|
3天前
|
SQL 数据管理 关系型数据库
如何在 Windows 上安装 SQL Server,保姆级教程来了!
在Windows上安装SQL Server的详细步骤包括:从官方下载安装程序(如Developer版),选择自定义安装,指定安装位置(非C盘),接受许可条款,选中Microsoft更新,忽略警告,取消“适用于SQL Server的Azure”选项,仅勾选必要功能(不包括Analysis Services)并更改实例目录至非C盘,选择默认实例和Windows身份验证模式,添加当前用户,最后点击安装并等待完成。安装成功后关闭窗口。后续文章将介绍SSMS的安装。
6 0
|
11天前
|
SQL 安全 网络安全
IDEA DataGrip连接sqlserver 提示驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接的解决方法
IDEA DataGrip连接sqlserver 提示驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接的解决方法
25 0