Postgresql:WHERE IN替代WHERE IN IN

时间:2009-11-20 09:36:36

标签: sql postgresql

我有几个语句访问非常大的Postgresql表,即:

SELECT a.id FROM a WHERE a.id IN ( SELECT b.id FROM b );
SELECT a.id FROM a WHERE a.id NOT IN ( SELECT b.id FROM b );

他们中的一些人甚至以这种方式访问​​更多的桌子。如果我切换到连接,那么提高性能的最佳方法是什么?

非常感谢!

3 个答案:

答案 0 :(得分:9)

JOIN效率会更高,或者您可以使用EXISTS:

SELECT a.id FROM a WHERE EXISTS (SELECT 1 FROM b WHERE b.id = a.id)

子查询最多返回1行。

答案 1 :(得分:3)

这是一种使用INNER JOIN过滤行的方法:

SELECT     a.id 
FROM       a 
INNER JOIN b ON a.id = b.id

请注意,每个版本的执行方式不同;有时IN更快,有时是EXISTS,有时是INNER JOIN。

答案 2 :(得分:0)

是的,我建议去加入。它将加速选择语句。