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语句有语法错误

 

希望能对大家有所帮助。

相关文章
|
17天前
|
SQL
SQL JOIN
【11月更文挑战第06天】
34 4
|
23天前
|
SQL 关系型数据库 MySQL
图解 SQL 里的各种 JOIN
用文氏图表示 SQL 里的各种 JOIN,一下子就理解了。
33 2
|
1月前
|
SQL 分布式计算 Java
Hadoop-11-MapReduce JOIN 操作的Java实现 Driver Mapper Reducer具体实现逻辑 模拟SQL进行联表操作
Hadoop-11-MapReduce JOIN 操作的Java实现 Driver Mapper Reducer具体实现逻辑 模拟SQL进行联表操作
31 3
|
3月前
|
Java 网络架构 数据格式
Struts 2 携手 RESTful:颠覆传统,重塑Web服务新纪元的史诗级组合!
【8月更文挑战第31天】《Struts 2 与 RESTful 设计:构建现代 Web 服务》介绍如何结合 Struts 2 框架与 RESTful 设计理念,构建高效、可扩展的 Web 服务。Struts 2 的 REST 插件提供简洁的 API 和约定,使开发者能快速创建符合 REST 规范的服务接口。通过在 `struts.xml` 中配置 `<rest>` 命名空间并使用注解如 `@Action`、`@GET` 等,可轻松定义服务路径及 HTTP 方法。
64 0
|
2月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
4月前
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
112 13
|
4月前
|
SQL
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
|
4月前
|
SQL 存储 网络安全
关系数据库SQLserver 安装 SQL Server
【7月更文挑战第26天】
60 6
|
4月前
|
存储 SQL C++
对比 SQL Server中的VARCHAR(max) 与VARCHAR(n) 数据类型
【7月更文挑战7天】SQL Server 中的 VARCHAR(max) vs VARCHAR(n): - VARCHAR(n) 存储最多 n 个字符(1-8000),适合短文本。 - VARCHAR(max) 可存储约 21 亿个字符,适合大量文本。 - VARCHAR(n) 在处理小数据时性能更好,空间固定。 - VARCHAR(max) 对于大文本更合适,但可能影响性能。 - 选择取决于数据长度预期和业务需求。
371 1
|
3月前
|
SQL 安全 Java
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“The server selected protocol version TLS10 is not accepted by client
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“The server selected protocol version TLS10 is not accepted by client
470 0