我什么都听不懂。我有大量数据和表的Oracle 11g db。我想加入一些表并输出它的结果。好吧,我刚写到:
SELECT *
FROM Table1
LEFT JOIN Table2 ON Table2.Table1_Id = Table1.Table1_Id
WHERE Table2.Column1=1
与第一次查询相比,该查询具有成本低、速度快等优点。为什么,我不明白?我在我的查询中使用了3个表,它工作得更快,然后用两个表进行查询(行数相同,数据相同)。
发布于 2015-02-02 16:15:06
首先是一些基本知识。这是您的第一个查询:
SELECT *
FROM Table1 t1 LEFT JOIN
Table2 t2
ON t2.Table1_Id = t1.Table1_Id
WHERE t2.Column1 = 1;
LEFT JOIN
是不必要的,因为WHERE
子句无论如何都会将它转换为INNER JOIN
。如果没有匹配,那么t2.Column1
是NULL
,它将被过滤掉。
我可以想象至少有一种方式你可以看到这个性能问题。基本上,如果Table2
在Table1_Id
上没有索引,但是它有一个Table3_Id
索引。
在这种情况下,第一个查询计划需要扫描Table2
(可能在Column1
上使用索引),然后执行数据库魔术--可能是表上的哈希连接。
第二个查询将使用可用的索引连接Table2
和Table3
。这将(大概)比Table2
小得多。数据库魔术可以避免对一个非常大的表进行全表扫描。
这是一种可能的情况。真正的方法是查看查询的执行计划,看看有什么不同。
https://stackoverflow.com/questions/28281205
复制相似问题