MySQL内外连接

MySQL内外连接

  • 表的连接分为内连接和外连接

内连接

  • 内连接实际上就是利用where子句对两种表形成的笛卡尔积进行筛选,也是开发中使用最多的连接查询

语法:

sql 复制代码
select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件;

​ 就是使用inner join table_2 on someting代替了原来的条件

外连接

  • 外连接分为左外连接和右外连接

左外连接

  • 使用左外连接,就是说左边的内容会被完全显示,但是右边的如果有匹配的就显示,如果没有匹配的就显示为NULL

语法:

sql 复制代码
select 字段名  from 表名1 left join 表名2 on 连接条件

eg:

sql 复制代码
-- 建两张表
create table stu (id int, name varchar(30)); -- 学生表
insert into stu values(1,'jack'),(2,'tom'),(3,'kity'),(4,'nono');
create table exam (id int, grade int); -- 成绩表
insert into exam values(1, 56),(2,76),(11, 8);

-- 查询所有学生的成绩,如果这个学生没有成绩,也要将学生的个人信息显示出来
-- 当左边表和右边表没有匹配时,也会显示左边表的数据
select * from stu left join exam on stu.id=exam.id; 

右外连接

sql 复制代码
select 字段 from 表名1 right join 表名2  on 连接条件;

eg:

sql 复制代码
-- 对stu表和exam表联合查询,把所有的成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来
select * from stu right join exam on stu.id=exam.id;

​ 其实右连接也可以使用左连接来实现,就是要换一下两个表的位置即可

相关推荐
东软吴彦祖12 分钟前
包安装利用 LNMP 实现 phpMyAdmin 的负载均衡并利用Redis实现会话保持nginx
linux·redis·mysql·nginx·缓存·负载均衡
慵懒的猫mi1 小时前
deepin分享-Linux & Windows 双系统时间不一致解决方案
linux·运维·windows·mysql·deepin
小高不明2 小时前
仿 RabbitMQ 的消息队列2(实战项目)
java·数据库·spring boot·spring·rabbitmq·mvc
DZSpace2 小时前
使用 Helm 安装 Redis 集群
数据库·redis·缓存
张飞光2 小时前
MongoDB 创建集合
数据库·mongodb
Hello Dam2 小时前
接口 V2 完善:基于责任链模式、Canal 监听 Binlog 实现数据库、缓存的库存最终一致性
数据库·缓存·canal·binlog·责任链模式·数据一致性
张飞光2 小时前
MongoDB 创建数据库
数据库·mongodb·oracle
摘星怪sec3 小时前
【漏洞复现】|方正畅享全媒体新闻采编系统reportCenter.do/screen.do存在SQL注入
数据库·sql·web安全·媒体·漏洞复现
基哥的奋斗历程3 小时前
学到一些小知识关于Maven 与 logback 与 jpa 日志
java·数据库·maven
苏-言3 小时前
MyBatis最佳实践:提升数据库交互效率的秘密武器
数据库·mybatis