PostgreSQL 横向连接性能较差



我有表格

dn_table ~ 10_000 rows
|  DN  |
--------
| 1234 |
| 1235 |
| .... |
sr_table ~ 1m rows
|  SR  |
--------
| 2345 |
| 2346 |
| .... |

我坚持对它们进行横向连接查询。它的性能非常差,某些查询在选择限制时根据数据集大小运行数小时。

select
*
from (
select
"alias1"."DN",
"alias2"."SR"
from (
select "alias1"."DN"
from "dn_table" as "alias1"
) as "alias1" left outer join lateral (
select *
from "sr_table" as "alias2"
where "alias1"."DN" = "alias2"."SR"
limit 1
) as "alias2" on true
) as "alias"

我尝试对它们使用相关的子查询,但它给我带来了我意想不到的结果。

提前感谢!

相关的子查询和横向连接应返回相同的结果。

但是对于横向连接,您需要在sr_table(SR)上建立索引。 您可能还需要一个order by,但这是一个语义问题,而不是性能问题。

如果确实添加了order by,则还需要将这些列包含在索引中。

最新更新