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
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 的区别
mysql 里面JOIN 和 INNER JOIN 区别是啥