postgresql 在查询中使用EXISTS可以提高性能吗?

xcitsw88  于 2024-01-07  发布在  PostgreSQL
关注(0)|答案(1)|浏览(216)

我有下面的查询,我使用DISTINCT,因为有关联,所以它给出了重复的值。但是否有可能实现它使用EXIST以及?

SELECT DISTINCT ON (cl.id)
    cl.id,
    cl.cid,
    cl.name
FROM locations cl
JOIN prop_loc pl ON (cl.cid = pl.cid AND cl.id = pl.loc_id)
JOIN prop_loc_prob plp ON (plp.cid = pl.cid AND plp.prop_id = pl.prop_id AND plp.loc_id = pl.loc_id)
JOIN prop_prob pp ON (plp.cid = pp.cid AND plp.prop_id = pp.prop_id AND plp.prob_id = pp.prob_id)
WHERE
    pl.prop_id = 12345 AND
    pl.cid = 123 
ORDER BY cl.id, cl.name

字符串
我们可以在EXISTS中使用以下两个严格JOINS吗?它是否提高了SQL性能?

JOIN prop_loc_prob plp ON (plp.cid = pl.cid AND plp.prop_id = pl.prop_id AND plp.loc_id = pl.loc_id)
JOIN prop_prob pp ON (plp.cid = pp.cid AND plp.prop_id = pp.prop_id AND plp.prob_id = pp.prob_id)

eivgtgni

eivgtgni1#

所有输出列都来自表locations。将其余所有列移动到EXISTS子查询表达式中。然后您可以完全删除聚合(没有GROUP BY):
比较所有候选查询与EXPLAIN ANALYZE的性能。

SELECT cl.id, cl.cid, cl.name
FROM   locations cl
WHERE  EXISTS (
   SELECT  -- can stay empty
   FROM   prop_loc      pl
   JOIN   prop_loc_prob plp USING (prop_id, loc_id, cid)
   JOIN   prop_prob     pp  USING (prop_id, cid)
   WHERE  pl.cid = cl.cid
   AND    pl.loc_id = cl.id
   AND    pl.prop_id = 12345
   AND    pl.cid = 123
   )
ORDER  BY cl.id, cl.name;

字符串

相关问题