我有几个语句访问非常大的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 );
他们中的一些人甚至以这种方式访问更多的桌子。如果我切换到连接,那么提高性能的最佳方法是什么?
非常感谢!
答案 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)
是的,我建议去加入。它将加速选择语句。