1、逗号关联操作符的效果与INNER JOIN相似:
select t1.*,t2.* from t1, t2 where t1.i = t2.i;
等价于:
select t1.*,t2.* from t1 INNER JOIN t2 where t1.i = t2.i;
注意,逗号关联操作符的优先级和其他联结类型不一样,有时还会导致语法错误,而其他联结操作符没有这个问题。应尽量避免使用逗号操作符。
2、using()子句:它在概念上类似on子句和where,但是要求被联结的列必须是同名的。
如:
select t1.*,t2.* from t1 inner join t2 using(i);
等价于:
select t1.*,t2.* from t1 inner join t2 on t1.i =t2.i;
3、如何消除自联结(也就是把一个数据表与它本身联结起来)。
这个时候需要用到别名,如:
select m1.name,m2.name from mytable as m1 inner join mytable as m2 where m1.name = m2.name
4、有关左联结和右联结(外联结)
内联结只能显示在两个数据表里都能找到的数据行。外联结除了显示了同样的结果,还可以把其中一个数据表在另一个数据表里面有匹配的数据行也显示出来。左联结把左数据表在右数据表里没有匹配的数据行也显示出来。右边表里没有的数据会显示NULL。