mysql 里面JOIN 和 INNER JOIN 区别是啥

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 里面JOIN 和 INNER JOIN 区别是啥相关的知识,希望对你有一定的参考价值。

SELECT a.* from a as a JOIN
(SELECT userName ,count(userName) as count FROM a GROUP BY `userName`) as b
WHERE
a.userName=b.userName
order BY b.count desc,b.userName asc
加了个inner显示结果不一样 之前一种以为join和inner join是等价的 看来不是

一、指代不同

1、JOIN:用于根据两个或多个表中的列之间的关系,从这些表中查询数据。

2、INNER JOIN :组合两个表中的记录,只要在公共字段之中有相符的值。

二、特点不同

1、JOIN:每个主键的值都是唯一的。这样做的目的是在不重复每个表中的所有数据的情况下,把表间的数据交叉捆绑在一起。

2、INNER JOIN :只要在这两个表的公共字段之中有相符值,内部联接将组合两个表中的记录。


三、规定不同

1、JOIN:如果表中有至少一个匹配,则返回行。

2、INNER JOIN :被联接的字段的名称。若不是由数字构成的,则这些字段必须为相同的数据类型并包含同类数据,但无须具有相同的名称。

参考资料来源:百度百科-INNER JOIN

参考资料来源:百度百科-SQL语句大全

参考技术A 但的确是等价的哦,没对比一下结果集中的记录是一样的吗?只是记录的顺序不一样哦。join是自然连接,对两张表中字段名和数据类型都相同的字段进行等值连接,并返回符合条件的结果,而inner join是内连接,显示符合连接条件的记录,连接条件已经指明了。这里需要注意join的时候和inner join连接时使用的连接条件是不一样的,所以在结果中记录出现的顺序会有所不同,但两个结果结合是一样的。

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 里面JOIN 和 INNER JOIN 区别是啥的主要内容,如果未能解决你的问题,请参考以下文章

MySQL中inner join 和 cross join 的区别

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

Mysql 连接(left join, right join, inner join ,full join)

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

Mysql 多表连接查询 inner join 和 outer join 的使用

mysql的unionleft join right join inner join和视图学习