https://blog.codinghorror.com/a-visual-explanation-of-sql-joins/
1. inner join:
所有满足join条件的两个table对应的row,column都将在result set中出现。比如下面的例子条件是tj1.id=tj2.id2而满足这个条件的row.
它的执行过程可以这样理解:获取tj1的第一行的id字段为1,随后比对tj2的id2字段,发现有三条记录出现,因此在结果集中就有了三条tj1.id=tj2.id2=1的记录,而
tj1.id=1的记录被复制了三份分别对应着tj2.id2=1的三条记录。接下来去比对tj1.id第二条记录2,在tj2.id2中又发现了2条记录,因此结果集中就出现2条记录。
继续往下tj1.id第三条记录3,在tj2.id2中只发现了1条记录,因此只出现1条记录。
2. left outer join
left outer join返回left table的所有row,并且附带上符合join条件的right table对应的matching row.
如果在right table中并没有发现对应列和left table的join条件满足matching,则返回null value
由于tj2表中有id2为8和9的两列tj1无对应记录存在因此以NULL填充.
执行的过程同样是先拿出left table的第一行id来检查得出right table的所有行中的id2为1的行,每找到这样一行就将其连同left table 的id=1 value=first形成新的一行(具体结果集出现哪些字段由select信息来决定)
3. right outer join
返回所有的right table行,以及满足matching条件的left table行信息,如果左表没有matching到右表对应的join条件时,则返回null.
执行过程依然是:针对右表的所有行,先取出第一行,再到左表中每一行查看是否有匹配join条件的,如发现满足,则将左表该行信息+右表的这行信息形成一行,直到左表扫描完毕。接下来继续右表的第二行,依次进行!
4. full outer join
由于mysql不支持full outer join,我们只能使用left/right outer join + union来模拟操作了。full outer join返回rows from either table when the conditions are met and retunrs a null value when there is no match
5. cross join
cross join不需要任何join条件,简单地返回row number1*row number2条记录
6. equi/non-equi join
在上面的inner/outer join中,对应的join条件都是t1.x=t2.y这种等值条件,也可以使用任何其他的非等值判断条件,比如t1.x>t2.y
7. self join
一个表和自己做inner/outer join