只需将一个连接从LEFT JOIN更改为LEFT HASH JOIN或“LEFT LOOP JOIN”,我的基本查询从6秒到1秒.任何人都可以解释为什么这会导致性能如此大幅度增加以及为什么sql的优化器不能自己解决它?
这大致是sql的样子:
SELECT a.[ID] FROM [TableA] a LEFT HASH JOIN [TableB] b ON b.[ID] = a.[TableB_ID] JOIN [TableC] c ON c.[ID] = a.[TableC_ID] WHERE a.[SomeDate] IS NULL AND a.[SomeStatus] IN ('X','Y','Z') AND c.[SomethingElse] = 'ABC'
表A和B在所有ID字段上都有数百万条记录和索引.使用sql Server 2005.
编辑:一位同事提出了一个LEFT LOOP JOIN,它似乎让它更快…… sql不是我的优势之一,所以我试图理解这些“暗示”是如何帮助的.