发布日期:2018-03-26
“INNER JOIN ON”子句对比“WHERE”子句+ 查看更多
“INNER JOIN ON”子句对比“WHERE”子句
+ 查看更多
发布日期:2018-02-23 09:53
分类:SQL
浏览次数:127
为了简单起见,假设所有相关字段都不为NULL。
你可以这样做:
SELECT table1.this, table2.that, table2.somethingelse FROM table1, table2 WHERE table1.foreignkey = table2.primarykey AND (一些其他条件)
或者这样做:
SELECT table1.this, table2.that, table2.somethingelse FROM table1 INNER JOIN table2 ON table1.foreignkey = table2.primarykey WHERE (一些其他条件)
在MYSQL中这两种方法的工作方式是相同的吗?
回答:
“INNER JOIN”是您应该使用的ANSI语法。
它通常被认为更具可读性,特别是当你加入大量的二维表时。
当需要时它也可以很容易地用“OUTER JOIN”替换。“WHERE”语法更多的是关系模型导向。
两个表使用“JOIN”语句的结果是应用了两个表的笛卡尔乘积并且过滤出具有连接列匹配的那些行。
使用“WHERE”语法更容易看出这一点。
至于你的例子,在MySQL(通常在SQL)中,这两个查询是同义词。
还要注意MySQL也有一个“STRAIGHT_JOIN”子句。
使用此子句,可以控制JOIN的顺序:哪个表在外循环中扫描,哪个表在内循环中。
你不能使用“WHERE”语法在MySQL中控制顺序。
它通常被认为更具可读性,特别是当你加入大量的二维表时。
当需要时它也可以很容易地用“OUTER JOIN”替换。“WHERE”语法更多的是关系模型导向。
两个表使用“JOIN”语句的结果是应用了两个表的笛卡尔乘积并且过滤出具有连接列匹配的那些行。
使用“WHERE”语法更容易看出这一点。
至于你的例子,在MySQL(通常在SQL)中,这两个查询是同义词。
还要注意MySQL也有一个“STRAIGHT_JOIN”子句。
使用此子句,可以控制JOIN的顺序:哪个表在外循环中扫描,哪个表在内循环中。
你不能使用“WHERE”语法在MySQL中控制顺序。