Postgresql:WHERE IN替代WHERE IN IN

MrG*_*MrG 5 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 );
Run Code Online (Sandbox Code Playgroud)

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

非常感谢!

Erl*_*ock 9

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

SELECT a.id FROM a WHERE EXISTS (SELECT 1 FROM b WHERE b.id = a.id)
Run Code Online (Sandbox Code Playgroud)

子查询最多返回1行.