微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Postgresql:WHERE IN替代WHERE IN IN

我有几个语句访问非常大的 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 );

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

非常感谢!

解决方法

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

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

查询最多返回1行.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐