8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

JOIN 比 WHERE 更快吗?

arunjitsingh 1月前

43 0

假设我有两个链接的表(一个表有另一个表的外键):CREATE TABLE Document(Id INT PRIMARY KEY,Name VARCHAR 255)CREATE TABLE DocumentStats(Id INT PRIMARY KEY...

假设我有两个链接的表(一个表有另一个表的外键):

CREATE TABLE Document (
  Id INT PRIMARY KEY,
  Name VARCHAR 255
)

CREATE TABLE DocumentStats (
  Id INT PRIMARY KEY,
  DocumentId INT, -- this is a foreign key to table Document
  NbViews INT
)

我知道,这不是最聪明的做事方式,但这是我能想到的最好的例子。

现在,我想获取所有浏览量超过 500 的文档。我想到两种解决方案:

SELECT *
FROM Document, DocumentStats
WHERE DocumentStats.Id = Document.Id
  AND DocumentStats.NbViews > 500

或者:

SELECT *
FROM Document
INNER JOIN DocumentStats ON Document.Id = DocumentStats.Id
WHERE DocumentStats.NbViews > 500

这两个查询是否等效,或者是否存在一种比另一种好得多的方法?如果是这样,为什么?

编辑:正如答案中所要求的,这个问题是针对 SQL Server 的,但我有兴趣知道它对于其他数据库引擎(MySQL 等)是否不同。

帖子版权声明 1、本帖标题:JOIN 比 WHERE 更快吗?
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由arunjitsingh在本站《performance》版块原创发布, 转载请注明出处!
最新回复 (0)
  • 显式连接更易于维护,因为查询的意图更清晰。此外,它们不会发生意外交叉连接,因此如果查询中有交叉连接,维护人员知道这是有意为之。

    如果您需要使用外连接,您应该知道 SQL Server 中已弃用 *= 语法,并且很快就会被删除。此外,它目前并非始终按预期运行,并且可能无法提供正确的结果,因此永远不应使用。混合使用显式外连接和 where 子句连接(隐式连接)会使维护人员更难阅读和理解查询。

返回
作者最近主题: