其实我对 数据库的级联或者联结查询一直都是会用,项目能查询出来自己想要的结果即可。
毕竟SQL使用复杂的查询毕竟比较少,而且不难使用。
至于区分他们,我还真的有点模糊。
在看 《SQL必知必会》这本书的时候,
from 多个表 和 级联 join 查询结果和 原理都是一样的。
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 .
其实他们两个是差不多。
也就是 以 from 的 表 为主, 如果 left join 的表没有 这个内容, 那么显示的内容就是空。
比如:
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 的缩写, 都是一样的
可以参考网友总结的更好
网友总结的
A left join B 的连接的记录数与A表的记录数同
A right join B 的连接的记录数与B表的记录数同
A left join B 等价B right join A
内连接 只连接匹配的行
左外连接 包含左边表的全部行(不管右边的表中是否存在与它们匹配的行),以及右边表中全部匹配的行
右外连接 包含右边表的全部行(不管左边的表中是否存在与它们匹配的行),以及左边表中全部匹配的行