其实我对 数据库的级联或者联结查询一直都是会用,项目能查询出来本身想要的结果便可。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
内链接 只链接匹配的行
左外链接 包含左边表的所有行(无论右边的表中是否存在与它们匹配的行),以及右边表中所有匹配的行
右外链接 包含右边表的所有行(无论左边的表中是否存在与它们匹配的行),以及左边表中所有匹配的行