CREATE TABLE testA aID int( 1 ) AUTO_INCREMENT PRIMARY KEY , aNum char( 20 ) ) CREATE TABLE testB( bID int( 1 ) NOT NULL AUTO_INCREMENT PRIMARY KEY , bName char( 20 ) ) 表testA记录如下: aID aNum 1 a11 2 a22 3 a33 4 a44 5 a55 表testB记录如下: bID bName 1 b11 2 b22 3 b33 4 b44 8 b88
1.left join(左联接)
sql语句如下: SELECT * FROM testA LEFT JOIN testB ON testA.aID = testB.bID 结果如下: aID aNum bID bName 1 a11 1 b11 2 a22 2 b22 3 a33 3 b33 4 a44 4 b44 5 a55 NULL NULL
left join是以A表的记录为基础的,testA可以看成左表,testB可以看成右表,左表(testA)的记录将会全部表示出来,而右表(testB)只会显示符合搜索条件的记录(例子中为: testA.aID = testB.bID). testB表记录不足的地方均为NULL.
2.right join(右联接)
sql语句如下: SELECT * FROM testA RIGHT JOING testB ON testA.aID = testB.bID 结果如下: aID aNum bID bName 1 a11 1 b11 2 a22 2 b22 3 a33 3 b33 4 a44 4 b44 NULL NULL 8 b88
仔细观察一下,就会发现,和left join的结果刚好相反,这次是以右表(testB)为基础的,testA表不足的地方用NULL填充.
3.inner join(相等联接或内联接)
sql语句如下: SELECT * FROM testA INNER JOIN testB ON testA.aID = testB.bID 等同于以下SQL句: SELECT * FROM testA,testB WHERE testA.aID = testB.bID 结果如下: aID aNum bID bName 1 a11 1 b11 2 a22 2 b22 3 a33 3 b33 4 a44 4 b44
很明显,这里只显示出了 testA.aID = testB.bID的记录.这说明inner join它只显示符合条件的记录.
相关推荐
inner join、 left join 、right join、 outer join之间的区别
SQL语句left join/right join/inner join 的用法比较 SQL语句left join/right join/inner join 的用法比较
(Left join , Right Join, Inner Join)用法详解,对Left join , Right Join, Inner Join完全掌握,由浅入深,真正领悟。
left join right join inner join 区别和联系
SQL中的left outer join,inner join,right outer join用法详解
通俗易懂的分析关联查询left,right,inner join
SQL语句inner join,left join ,right join连接的不同之处, 非常实用
比较实用的方法,已经用到项目里,很好用的一个方法
Left join , Right Join, Inner Join 的相关内容,非常实用
Mysql之innerjoin,leftjoin,rightjoin详解.pdf
SQL 外链接操作小结 inner join left join right join
NULL 博文链接:https://appofis.iteye.com/blog/467692
主要介绍了SQL之left join、right join、inner join的区别浅析,本文讲解了它们的区别并给出了实例,需要的朋友可以参考下
Join on/inner join on/full join on/full outer join on/left join on/right join on/cross join on; 在使用jion时,on和where条件的区别;
对于开发使用到数据库的应用,免不了就要使用联合查询,SQL中常用的联合查询有inner join、outer join和cross join;这三者的区别很多人都应该不是很清楚,包括我自己,下面我们一起来看看,如果你使用join连表,...
下面是例子分析表A记录如下: aID aNum 1 a20050111 2 a20050112 3 a20050113 4 a20050114 5 a20050115 表B记录如下: bID bName 1 2006032401 2 2006032402 3 2006032403 4 2006032404 8 2006032408 ...
表的数据有:一、内连接-inner jion :最常见的连接查询可能是这样,查出学生的名字和成绩:[sql] view plain copy select s.