join连接的区别 mysql sql中join in 和join区别_join连接的区别 mysql

 

 

SQL JOIN 子句用于把来自两个或多个表的行结合起来,基于这些表之间的共同字段。

最常见的 JOIN 类型:SQL INNER JOIN                                                --内连接

 LEFT JOIN、 RIGHT JOIN、 FULL JOIN                   --外链接

cross join                                                                                                  --交叉连接

 

 

 

 

 

left join -2

right join -2

full out join -2

inner join

id

name

1

Google

2

淘宝

3

微博

4

Facebook

table 1

id

address

1

美国

5

中国

3

中国

6

美国

 

 table 2

一、INNER JOIN


 

内连接是最常见的一种连接,只连接匹配的行。

inner join语法

select column_name(s)
from table 1
INNER JOIN table 2
ON
table 1.id=table 2.column_name

注释:INNER JOIN与JOIN是相同

join连接的区别 mysql sql中join in 和join区别_SQL_02

INNER JOIN产生的结果集中,是1和2的交集。

select * from Table A inner join Table B
on Table A.id=Table B.id

 执行以上SQL输出结果如下:

id

name

address

1

Google

美国

3

微博

中国

 

 

二、LEFT JOIN


 

LEFT JOIN返回左表的全部行和右表满足ON条件的行,如果左表的行在右表中没有匹配,那么这一行右表中对应数据用NULL代替。

LEFT JOIN 语法

select column_name(s)
from table 1
LEFT JOIN table 2
ON table 1.column_name=table 2.column_name

注释:在某些数据库中,LEFT JOIN 称为LEFT OUTER JOIN

join连接的区别 mysql sql中join in 和join区别_join连接的区别 mysql_03

LEFT JOIN产生表1的完全集,而2表中匹配的则有值,没有匹配的则以null值取代。

select * from Table A left join Table B
on Table A.id=Table B.id

 执行以上SQL输出结果如下:

id

name

address

1

Google

美国

2

淘宝

null

3

微博

中国

4

Facebook

null

 

 

 

 三、RIGHT JOIN


 

RIGHT JOIN返回右表的全部行和左表满足ON条件的行,如果右表的行在左表中没有匹配,那么这一行左表中对应数据用NULL代替。

RIGHT JOIN语法

select column_name(s)
from table 1
RIGHT JOIN table 2
ON table 1.column_name=table 2.column_name

注释:在某些数据库中,RIGHT JOIN 称为RIGHT OUTER JOIN

join连接的区别 mysql sql中join in 和join区别_Google_04

RIGHT JOIN产生表2的完全集,而1表中匹配的则有值,没有匹配的则以null值取代。

select * from Table A right join Table B
on Table A.id=Table B.id

执行以上SQL输出结果如下:

id

name

address

1

Google

美国

5

null

中国

3

微博

中国

6

null

美国

 

 

 

四、FULL OUTER JOIN


 

FULL JOIN 会从左表 和右表 那里返回所有的行。如果其中一个表的数据行在另一个表中没有匹配的行,那么对面的数据用NULL代替

FULL OUTER JOIN语法

select column_name(s)
from table 1
FULL OUTER JOIN table 2
ON table 1.column_name=table 2.column_name

 

join连接的区别 mysql sql中join in 和join区别_sql_05

FULL OUTER JOIN产生1和2的并集。但是需要注意的是,对于没有匹配的记录,则会以null做为值。

select * from Table A full outer join Table B
on Table A.id=Table B.id

执行以上SQL输出结果如下:

id

name

address

1

Google

美国

2

淘宝

null

3

微博

中国

4

Facebook

null

5

null

中国

6

null

美国

 

 五、CROSS JOIN

 

如果不带WHERE条件子句,它将会返回被连接的两个表的笛卡尔积,返回结果的行数等于两个表行数的乘积;

举例,下列A、B、C 执行结果相同,但是效率不一样:

A:SELECT * FROM table1 CROSS JOIN table2

B:SELECT * FROM table1,table2

 

表a

 

join连接的区别 mysql sql中join in 和join区别_join连接的区别 mysql_06

 

 表b

join连接的区别 mysql sql中join in 和join区别_Google_07

 

1.select *  from salary a full outer join salarya b on a.product_id =b.product_id

上面sql的结果是

join连接的区别 mysql sql中join in 和join区别_sql_08

 

 

2.select *  from salary a,salarya b where a.product_id =b.product_id

上面sql的结果是

join连接的区别 mysql sql中join in 和join区别_SQL_09

3.select *  from salary a inner  join salarya b on a.product_id =b.product_id

上面sql的结果是

join连接的区别 mysql sql中join in 和join区别_SQL_10