mysql 联结,级联查询总结区分

其实我对 数据库的级联或者联结查询一直都是会用,项目能查询出来本身想要的结果便可。html

毕竟SQL使用复杂的查询毕竟比较少,并且不难使用。sql

至于区分他们,我还真的有点模糊。数据库

在看 《SQL必知必会》这本书的时候,code

from 多个表 和 级联 join  查询结果和 原理都是同样的。htm

SELECT a.id,b.id from userbasicsinfo a,userbank b
where a.id=b.user_id;

SELECT a.id,b.id from userbasicsinfo a
INNER JOIN
userbank b on a.id=b.user_id;

SELECT a.id,b.id from userbasicsinfo a
 JOIN
userbank b on a.id=b.user_id;

以上 3中写法都是同样的,原理都是同样的。
只是 from 多个表查询,可能对于某些人看来有点不规范而已。

 

剩下的用的比较多的就是  left join , 反正我是没用过 right join .blog

其实他们两个是差很少。get

也就是 以 from 的 表 为主, 若是 left join  的表没有 这个内容, 那么显示的内容就是空。class

好比:原理

SELECT a.id,b.id from userbasicsinfo a
 LEFT OUTER JOIN
userbank b on a.id=b.user_id;



结果:

id  id1
1   
2    1
3

 

 

 

left join 就是   LEFT OUTER JOIN  的缩写, 都是同样的im

能够参考网友总结的更好

网友总结的

  A   left   join   B   的链接的记录数与A表的记录数同  
  A   right   join   B   的链接的记录数与B表的记录数同    
  A   left   join   B   等价B   right   join   A  

内链接        只链接匹配的行
左外链接        包含左边表的所有行(无论右边的表中是否存在与它们匹配的行),以及右边表中所有匹配的行
右外链接        包含右边表的所有行(无论左边的表中是否存在与它们匹配的行),以及左边表中所有匹配的行

相关文章
相关标签/搜索