显式内连接和隐式内连接在效率上有区别吗? 例如:

SELECT * FROM
table a INNER JOIN table b
ON a.id = b.id;

vs.

SELECT a.*, b.*
FROM table a, table b
WHERE a.id = b.id;

当前回答

@lomaxx:澄清一下,我非常确定SQL Serv 2005支持上述两种语法。但是不支持下面的语法

select a.*, b.*  
from table a, table b  
where a.id *= b.id;

具体来说,不支持外部连接(*=)。

其他回答

第二种语法具有不必要的交叉连接的可能性:您可以向FROM部分添加表而不对应WHERE子句。这被认为是有害的。

在一些数据库(尤其是Oracle)中,连接的顺序会对查询性能产生巨大的影响(如果有两个以上的表)。在一个应用程序中,我们在某些情况下有两个数量级的差异。如果使用正确的提示语法,使用内部连接语法可以控制这一点。

您没有指定使用哪个数据库,但可能建议使用SQL Server或MySQL,在那里它没有真正的区别。

@lomaxx:澄清一下,我非常确定SQL Serv 2005支持上述两种语法。但是不支持下面的语法

select a.*, b.*  
from table a, table b  
where a.id *= b.id;

具体来说,不支持外部连接(*=)。

在性能方面,它们是完全相同的(至少在SQL Server中)。

PS:请注意,自SQL Server 2005以来,隐式OUTER JOIN语法已弃用。(仍然支持问题中使用的隐式INNER JOIN语法)

“旧样式”JOIN语法的弃用:只是部分内容

基本上,两者之间的区别是一个是用旧的方式写的,而另一个是用现代的方式写的。就我个人而言,我更喜欢使用内、左、外、右定义的现代脚本,因为它们更具解释性,并且使代码更具可读性。

当处理内部连接时,在可读性上也没有真正的区别,然而,当处理左连接和右连接时可能会变得复杂,因为在旧的方法中,你会得到这样的东西:

SELECT * 
FROM table a, table b
WHERE a.id = b.id (+);

上面是左连接的旧写法,而不是下面的写法:

SELECT * 
FROM table a 
LEFT JOIN table b ON a.id = b.id;

正如您可以直观地看到的,编写脚本的现代方式使查询更具可读性。(顺便说一下,右连接也是一样的,外连接稍微复杂一点)。

回到锅炉板,查询的编写方式对SQL编译器来说并没有什么不同,因为它以相同的方式处理查询。我在Oracle数据库中看到了两者的混合,有很多人在其中写东西,有年长的也有年轻的。同样,这可以归结为脚本的可读性以及与您一起开发的团队。