假设我有两个链接的表(一个表有另一个表的外键):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 等)是否不同。
如果您专门谈论 SQL Server,那么您绝对应该使用 INNER JOIN 语法。除了(个人意见警告!)更易于阅读和意图更清晰之外,截至 SQL Server 2005,没有用于外连接的等效语法。2005 默认不支持 *= 和 =* 语法 - 您需要启用兼容模式才能支持它。它最终将被删除,可能在下一个版本中(或可能不会!)
这意味着:
还要注意,与普遍看法相反,这两者并不 等同 。有些事情更加棘手,有些事情根本不可能实现。Kalen Delaney 的 《Inside SQL Server 2000》 介绍了一些示例;不确定新版本是否包括,因为无论如何该连接语法已被弃用。