gpt4 book ai didi

sql - 如何提高使用表值函数的查询的性能?

转载 作者:行者123 更新时间:2023-11-29 11:57:24 25 4
gpt4 key购买 nike

我有一个查询的形式:

SELECT a.id, b.colb, c.colc, d.cold, ...
FROM a JOIN b on a.id=b.id
JOIN c on a.id=c.id
JOIN d on a.id=d.id
JOIN e on a.id=e.id
...

这里的每一个表其实都是一个表值函数。此查询的运行时间超过一分钟,但当我手动创建临时表(CREATE TEMPORARY TABLE ax as SELECT * from a)并针对这些表运行查询时,需要几毫秒(并创建表也需要几毫秒)。

是什么导致了这种巨大的性能差异(至少两个数量级)?

最佳答案

PostgreSQL 优化器可能会选择将您的联接执行为 loop join .也就是说,它将评估每个左侧行的函数调用。

您使用临时表的解决方案是避免这种情况的绝佳方法。即使优化器希望再次使用 loop join,结果也会是在临时表中进行大量查找。查找比函数的重复评估便宜一个数量级。

关于sql - 如何提高使用表值函数的查询的性能?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15855767/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com