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,就分享到这里吧!


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
5天前
|
SQL NoSQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(5)作者——LJS[含MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页等详解步骤及常见报错问题所对应的解决方法]
MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页、INSERT INTO SELECT / FROM查询结合精例等详解步骤及常见报错问题所对应的解决方法
|
10天前
|
SQL Java 关系型数据库
java连接mysql查询数据(基础版,无框架)
【10月更文挑战第12天】该示例展示了如何使用Java通过JDBC连接MySQL数据库并查询数据。首先在项目中引入`mysql-connector-java`依赖,然后通过`JdbcUtil`类中的`main`方法实现数据库连接、执行SQL查询及结果处理,最后关闭相关资源。
|
6天前
|
SQL 关系型数据库 MySQL
定时任务频繁插入数据导致锁表问题 -> 查询mysql进程
定时任务频繁插入数据导致锁表问题 -> 查询mysql进程
18 1
|
13天前
|
SQL JavaScript 关系型数据库
node博客小项目:接口开发、连接mysql数据库
【10月更文挑战第14天】node博客小项目:接口开发、连接mysql数据库
|
19天前
|
Java 关系型数据库 MySQL
【编程基础知识】Eclipse连接MySQL 8.0时的JDK版本和驱动问题全解析
本文详细解析了在使用Eclipse连接MySQL 8.0时常见的JDK版本不兼容、驱动类错误和时区设置问题,并提供了清晰的解决方案。通过正确配置JDK版本、选择合适的驱动类和设置时区,确保Java应用能够顺利连接MySQL 8.0。
92 1
|
23天前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
35 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库
|
4天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
19 0
|
5天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第26天】数据库作为现代应用系统的核心组件,其性能优化至关重要。本文主要探讨MySQL的索引策略与查询性能调优。通过合理创建索引(如B-Tree、复合索引)和优化查询语句(如使用EXPLAIN、优化分页查询),可以显著提升数据库的响应速度和稳定性。实践中还需定期审查慢查询日志,持续优化性能。
25 0
|
7天前
|
SQL 关系型数据库 MySQL
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
14 0
|
30天前
|
存储 SQL 关系型数据库
MySQL 给查询结果增列并自定义列数据
MySQL 给查询结果增列并自定义列数据
283 2