mysql inner join如何显示记录为空的数据

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql inner join如何显示记录为空的数据相关的知识,希望对你有一定的参考价值。

问题描述:
2张表格:
表格A:
id name b_id

1 aa 1
2 bb 2
3 cc null
表格B:
id num
1 33
2 44

SQL语句:select * from A as a inner join B as b on a.b_id=b.id;显示数据为:
id name b_id id num
1 aa 1 1 33
2 bb 2 2 44

怎么写SQL语句,能显示A表格里的所有数据呢?我想要显示的结果为:
id name b_id id num
1 aa 1 1 33
2 bb 2 2 44
3 cc null null null

参考技术A inner join在连接表没有对应数据时主表数据也不会出来。
left join在连接表没有对应数据时主表数据会出来,连接表数据以null列出。
所以换一下就行了!本回答被提问者和网友采纳

Mysql之inner join,left join,right join详解

首先借用官方的解释下:

inner join(等值连接):只返回两个表中联结字段相等的行;

left join(左联接):返回包括左表中的所有记录和右表中联结字段相等的记录;

right join(右联接):返回包括右表中的所有记录和左表中联结字段相等的记录。

比如我们有table1、table2两个表

 

table1表                                 table2表

---------------                  ----------------------

id     name                     id      score

1      lee                      1       90

2      zhang                    2       100
4      wang                     3       70

  

Sql代码

create table table1(id int,name varchar(10));
create table table2(id int,score int);

 

INSERT INTO table1 (id,NAME) VALUES (‘1‘,‘lee‘),(‘2‘,‘zhang‘),(‘4‘,‘wang‘);

INSERT INTO table2 (id,score) VALUES (‘1‘,90),(‘2‘,100),(‘3‘,70);

  

  

以下均在查询分析器中执行

一、外连接
1.概念:包括左向外联接、右向外联接或完整外部联接

2.左连接:left join 或 left outer join
(1)左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值(null)。
(2)sql 语句

select * from table1 left join table2 on table1.id=table2.id;

-------------结果-------------
技术分享
注释:包含table1的所有子句,根据指定条件返回table2相应的字段,不符合的以null显示

3.右连接:right join 或 right outer join
(1)右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。
(2)sql 语句

select * from table1 right join table2 on table1.id=table2.id;

-------------结果-------------
技术分享
注释:包含table2的所有子句,根据指定条件返回table1相应的字段,不符合的以null显示

4.完整外部联接:full join 或 full outer join
(1)完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。
(2)sql 语句

select * from table1 full join table2 on table1.id=table2.id;

-------------结果-------------
idnameidscore
------------------------------
1lee190
2zhang2100
4wangNULLNULL
NULLNULL370
------------------------------
注释:返回左右连接的和(见上左、右连接)

 

二、内连接
1.概念:内联接是用比较运算符比较要联接列的值的联接

2.内连接:join 或 inner join

3.sql 语句

select * from table1 join table2 on table1.id=table2.id;

-------------结果-------------
技术分享
注释:只返回符合条件的table1和table2的列

4.等价(与下列执行效果相同)

A:select a.*,b.* from table1 a,table2 b where a.id=b.id;

B:select * from table1 cross join table2 where table1.id=table2.id; (注:cross join后加条件只能用where,不能用on)

  

三、交叉连接(完全)

1.概念:没有 WHERE 子句的交叉联接将产生联接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。(table1和table2交叉连接产生3*3=9条记录)

2.交叉连接:cross join (不带条件where...)

3.sql语句

select * from table1 cross join table2;

-------------结果-------------
技术分享
注释:返回3*3=9条记录,即笛卡尔积

4.等价(与下列执行效果相同)

A:select * from table1,table2;

  

 

以上是关于mysql inner join如何显示记录为空的数据的主要内容,如果未能解决你的问题,请参考以下文章

MySQL中inner join 和 cross join 的区别

EF Core Inner join 改为 Left

MySql INNER JOIN三表联查性能如何提升

mysql 里面JOIN 和 INNER JOIN 区别是啥

mysql left join,right join,inner join的区别

Mysql之inner join,left join,right join详解