mysql的几种join

之前学习mysql的时候对于老师说的左连接,右连接…之类的概念一直不清楚,模模糊糊的。工作之后理解这些名词一概念,现在把它记录一下。也希望能够帮助对于mysql中join不太清晰的朋友。这样可以根据自己的业务场景选择合适的join语句。

初始化SQL语句:

/*join 建表语句*/
drop database if exists test;
create database test;
use test;

/* 左表t1*/
drop table if exists t1;
create table t1 (id int not null,name varchar(20));
insert into t1 values (1,'t1a');
insert into t1 values (2,'t1b');
insert into t1 values (3,'t1c');
insert into t1 values (4,'t1d');
insert into t1 values (5,'t1f');

/* 右表 t2*/
drop table if exists t1;
create table t2 (id int not null,name varchar(20));
insert into t2 values (2,'t2b');
insert into t2 values (3,'t2c');
insert into t2 values (4,'t2d');
insert into t2 values (5,'t2f');
insert into t2 values (6,'t2a');

1、笛卡尔积

两表关联,把左表的列和右表的列通过笛卡尔积的形式表达出来。

mysql> select * from t1 join t2;

这里写图片描述

2、左连接

两表关联,左表全部保留,右表关联不上用null表示。

这里写图片描述

mysql> select * from t1 left join t2 on t1.id = t2.id;

这里写图片描述

3、右连接

右表全部保留,左表关联不上的用null表示。

这里写图片描述

mysql> select * from t1 right join t2 on t1.id =t2.id;

这里写图片描述

4、内连接

两表关联,保留两表中交集的记录。

这里写图片描述

mysql> select * from t1 inner join t2 on t1.id = t2.id;

这里写图片描述

5、左表独有

两表关联,查询左表独有的数据。

这里写图片描述

mysql> select * from t1 left join t2 on t1.id = t2.id where t2.id is null;

这里写图片描述

6、右表独有

两表关联,查询右表独有的数据。

这里写图片描述

mysql> select * from t1 right join t2 on t1.id = t2.id where t1.id is  null;

这里写图片描述

7、全连接

两表关联,查询它们的所有记录。

这里写图片描述

oracle里面有full join,但是在mysql中没有full join。我们可以使用union来达到目的。

mysql> select * from t1 left join t2 on t1.id = t2.id
    -> union 
    -> select * from t1 right join t2 on t1.id = t2.id;

这里写图片描述

8、并集去交集

两表关联,取并集然后去交集。

这里写图片描述

mysql> select * from t1 left join t2 on t1.id = t2.id where t2.id is null
    -> union 
    -> select * from t1 right join t2 on t1.id = t2.id where t1.id is null;

这里写图片描述

  • 15
    点赞
  • 67
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
SQL语句中,常见的几种JOIN操作包括INNER JOIN、LEFT JOIN、RIGHT JOIN以及FULL JOIN。它们的区别如下: INNER JOIN:内连接是基于两个表之间的共同值进行匹配,返回两个表中满足连接条件的交集。这意味着只有在两个表中都存在的匹配行才会被返回。 LEFT JOIN:左连接返回左表中的所有行,以及与右表中匹配的行。如果在右表中没有匹配的行,则以NULL填充右侧的列。 RIGHT JOIN:右连接返回右表中的所有行,以及与左表中匹配的行。如果在左表中没有匹配的行,则以NULL填充左侧的列。 FULL JOIN:全连接是左连接和右连接的组合,返回左表和右表的并集。对于没有匹配的记录,将使用NULL表示。 需要注意的是,在MySQL中,并不直接支持FULL JOIN操作。可以使用左连接和右连接的合集来实现FULL JOIN的效果。 综上所述,INNER JOIN返回两个表的交集,LEFT JOIN返回左表和右表的交集以及左表中没有匹配的行,RIGHT JOIN返回左表和右表的交集以及右表中没有匹配的行,FULL JOIN返回左表和右表的并集,并包含所有的匹配和未匹配的行。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [一起学习SQL中各join以及它们的区别](https://blog.csdn.net/qq_41153943/article/details/125565202)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值