JOIN -MYSQL

xiaoxiao2026-04-11  3

left join :左连接,返回左表中所有的记录以及右表中连接字段相等的记录。 right join :右连接,返回右表中所有的记录以及左表中连接字段相等的记录。 inner join: 内连接,又叫等值连接,只返回两个表中连接字段相等的行。 full join:外连接,返回两个表中的行:left join + right join (mysql无)cross join:结果是笛卡尔积,就是第一个表的行数乘以第二个表的行数。

 

CREATE TABLE a (a int,b int);CREATE TABLE b (a int,b int) ;insert a values(1,1); insert a values(2,2) ;insert b values(1,1); insert b values(3,3) ;

select * from a; select * from b; --左: select * from a Aa left join b Bb on Aa.a=Bb.a ;a b a b1 1 1 12 2 \N \N

 

--右: select * from a Aa right join b Bb on Aa.a=Bb.a ;1 1 1 1\N \N 3 3

 

--内 select * from a Aa inner join b Bb on Aa.a=Bb.a 1 1 1 1

 

--自然: select * from a Aa NATURAL JOIN  b Bb 1 1

 

--交叉连接 select * from a cross join b select * from a join b select * from a Aa STRAIGHT_JOIN  b Bb1 1 1 12 2 1 11 1 3 32 2 3 3

附转:declare @a table(a int,b int) declare @b table(a int,b int) insert @a values(1,1) insert @a values(2,2) insert @b values(1,1) insert @b values(3,3) select * from @a select * from @b --左: select * from @a Aa left join @b Bb on Aa.a=Bb.a --右: select * from @a Aa right join @b Bb on Aa.a=Bb.a --内 select * from @a Aa inner join @b Bb on Aa.a=Bb.a --外: select * from @a Aa full join @b Bb on Aa.a=Bb.a --交叉连接 select * from @a cross join @b

 

转载请注明原文地址: https://www.6miu.com/read-5047190.html

最新回复(0)