mysql的连接查询

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 首先创建两张表,一个student_table,一个salary。表名起的不是合乎情景,就这样吧。use mysql;create table student_table(id varchar(25),name varchar(25),brith varchar(25),sex varchar(25));insert into student_tablevalues('1004' , '张三' ,'2000-08-06' , '男'),('1009' , '李四', '2000-01-01', '男'),('1010' , '李四', '2001-01-01', '男'

首先创建两张表,一个student_table,一个salary。表名起的不是合乎情景,就这样吧。


use mysql;
create table student_table(
id varchar(25),
name varchar(25),
brith varchar(25),
sex varchar(25)
);
insert into student_table
values
('1004' , '张三' ,'2000-08-06' , '男'),
('1009' , '李四', '2000-01-01', '男'),
('1010' , '李四', '2001-01-01', '男'),
('1006' , '王五', '2000-08-06' , '女'),
('1008' , '张三', '2002-12-01', '女'),
('1012' , '张三', '2001-12-01', '女'),
('1011' , '李四', '2002-08-06' , '女'),
('1013' , '赵六' ,'2000-09-06' , '男');
create table salary(
  sid varchar(25),
  department varchar(25),
  salary int(10)
);
insert into salary
values
  ("1004","后勤",10000),
  ("1009","行政",11000),
  ("1011","研发",19000),
  ("1010","后勤",9000),
  ("1013","研发",25000),
  ("1006","销售",15000),
  ("1012","研发",6000);


创建的两个表




内连接

现在我要进行一个内连接查询


select a.*,b.* from student_table a inner join salary b on a.id = b.sid; -- 内连接


得到的查询结果是



可以发现这个查询的显示就是根据id 和 sid 进行匹配,如果有匹配的值,那么就会连接到一行,作为结果,如果id和sid有出现不匹配的项的话,不会进行返回结果。


左连接

那么现在进行一个左连接


select  a.*,b.* from student_table a left join salary b on a.id = b.sid; -- 左连接


得到的结果是



你会发现左连接left 左边表的所有字段都会保留都会保留,即使存在没有匹配到的数据。而left右边的表数据没有匹配到左边表的数据就会被设为null。也就是说这样的连接是已left左边的表为基准。


右连接

相对的右连接,那就是按照右边的表进行匹配。


select a.*,b.* from student_table a right join salary b on a.id = b.sid; -- 右连接



注意我右边表的sid在左边表是完全可以匹配到的,所以这里不会出现空。按照右边为基础,左边


多余的id对应的数据是不会显示的。要的是匹配的数据,右表的数据都可以匹配上,所以不会出现null。


你注意到的可能是表中有两个王五,但是这里也不影响,毕竟工资和部门是不一样的。所以不要认为是冗余的数据哦。


全连接

这不是有手就行?全连接当然就是左连接和右连接的结合啦。


本来的代码


select a.*,b.* from student_table a full join salary b on a.id = b.sid;


但是mysql 8的版本还没有被支持,所以我们可以这样去实现全连接


select  a.*,b.* from student_table a left join salary b on a.id = b.sid union select a.*,b.* from student_table a right join salary b on a.id = b.sid;



这样你会想,那这样不是和左连接的效果一样吗?是的,效果是一样的,但是其实是不一样的,左连接会以左表为基准,左边表的数据都会显示,没有匹配到的数据会被设置为null。全连接会全部作为基准,相对的没有匹配到的也会同样的设置为null,但是我们的salary作为基准的时候左表是完全匹配的,所以不会出现null。


那么现在在salary添加一个条数据,让student_table没有的数据。然后再次进行一次全连接查询。


insert into salary values(10086,"安全",18000);


salary 表



student_table 表是没有变



ok ,再次运行全连接代码


select  a.*,b.* from student_table a left join salary b on a.id = b.sid union select a.*,b.* from student_table a right join salary b on a.id = b.sid;



你看这样就非常形象的说明了。


再来看一张图,分别对应内连接,左连接,右连接,全连接。完完全全明白。



用语雀写的文章,导出md后又导入了这个编辑器。对图片的显示做了处理。


记录一下,Ctrl+G 调出替换窗口,将[object Object]替换为%5Bobject%20Object%5D就完事。



语雀这个太好用了。感觉非常丝滑,这个用来写笔记。本来是作为笔记,还是按照博客的文章模式来写了。以后就用语雀写完,然后导入到这里。非常喜欢。



说了些废话,ok,就分享到这里吧!


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
2月前
|
SQL 缓存 监控
MySQL缓存机制:查询缓存与缓冲池优化
MySQL缓存机制是提升数据库性能的关键。本文深入解析了MySQL的缓存体系,包括已弃用的查询缓存和核心的InnoDB缓冲池,帮助理解缓存优化原理。通过合理配置,可显著提升数据库性能,甚至达到10倍以上的效果。
|
2月前
|
SQL 存储 关系型数据库
MySQL体系结构详解:一条SQL查询的旅程
本文深入解析MySQL内部架构,从SQL查询的执行流程到性能优化技巧,涵盖连接建立、查询处理、执行阶段及存储引擎工作机制,帮助开发者理解MySQL运行原理并提升数据库性能。
|
4月前
|
SQL 人工智能 关系型数据库
如何实现MySQL百万级数据的查询?
本文探讨了在MySQL中对百万级数据进行排序分页查询的优化策略。面对五百万条数据,传统的浅分页和深分页查询效率较低,尤其深分页因偏移量大导致性能显著下降。通过为排序字段添加索引、使用联合索引、手动回表等方法,有效提升了查询速度。最终建议根据业务需求选择合适方案:浅分页可加单列索引,深分页推荐联合索引或子查询优化,同时结合前端传递最后一条数据ID的方式实现高效翻页。
212 0
|
2月前
|
SQL 关系型数据库 MySQL
MySQL的查询操作语法要点
储存过程(Stored Procedures) 和 函数(Functions) : 储存过程和函数允许用户编写 SQL 脚本执行复杂任务.
176 14
|
2月前
|
SQL 关系型数据库 MySQL
MySQL的查询操作语法要点
以上概述了MySQL 中常见且重要 的几种 SQL 查询及其相关概念 这些知识点对任何希望有效利用 MySQL 进行数据库管理工作者都至关重要
81 15
|
2月前
|
SQL 监控 关系型数据库
SQL优化技巧:让MySQL查询快人一步
本文深入解析了MySQL查询优化的核心技巧,涵盖索引设计、查询重写、分页优化、批量操作、数据类型优化及性能监控等方面,帮助开发者显著提升数据库性能,解决慢查询问题,适用于高并发与大数据场景。
|
2月前
|
SQL Java 关系型数据库
Java连接MySQL数据库环境设置指南
请注意,在实际部署时应该避免将敏感信息(如用户名和密码)硬编码在源码文件里面;应该使用配置文件或者环境变量等更为安全可靠地方式管理这些信息。此外,在处理大量数据时考虑使用PreparedStatement而不是Statement可以提高性能并防止SQL注入攻击;同时也要注意正确处理异常情况,并且确保所有打开过得资源都被正确关闭释放掉以防止内存泄漏等问题发生。
87 13
|
2月前
|
SQL 关系型数据库 MySQL
MySQL数据库连接过多(Too many connections)错误处理策略
综上所述,“Too many connections”错误处理策略涉及从具体参数配置到代码层面再到系统与架构设计全方位考量与改进。每项措施都需根据具体环境进行定制化调整,并且在执行任何变更前建议先行测试评估可能带来影响。
700 11
|
2月前
|
SQL 关系型数据库 MySQL
排除通过IP访问MySQL时出现的连接错误问题
以上步骤涵盖了大多数遇到远程连接 MySQL 数据库时出现故障情形下所需采取措施,在执行每个步骤后都应该重新尝试建立链接以验证是否已经解决问题,在多数情形下按照以上顺序执行将能够有效地排除并修复大多数基本链接相关故障。
253 3
|
2月前
|
SQL 监控 关系型数据库
查寻MySQL或SQL Server的连接数,并配置超时时间和最大连接量
以上步骤提供了直观、实用且易于理解且执行的指导方针来监管和优化数据库服务器配置。务必记得,在做任何重要变更前备份相关配置文件,并确保理解每个参数对系统性能可能产生影响后再做出调节。
281 11

推荐镜像

更多
下一篇
开通oss服务