【发布时间】:2010-11-10 22:10:15
【问题描述】:
假设我有两个链接的表(一个有一个外键到另一个):
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 等)不同。
【问题讨论】:
-
什么数据库? SQL 女士、MySQL、SQLite、甲骨文...?
-
这被称为显式连接与隐式连接,之前有人问过:stackoverflow.com/questions/44917/…
-
@Theo:主要是 MSSQL,但我也会对其他人感兴趣... @Paolo:谢谢,我不知道它是那样的调用。我尝试使用 JOIN vs WHERE 进行搜索,但找不到答案。
-
在不同的搜索条件下两次将其放入系统中没有什么坏处。 :)
标签: sql performance join where-clause