sql - 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
,您还需要将这些列包含在索引中。
推荐阅读
- sql - SQL连接到表中的多行
- position - 如何在 Hololens 上获得手的位置?
- reactjs - 使用 useState React 钩子时从状态中获取空数据
- asp.net - 浏览器如何读取 Web.config 中的连接字符串?
- javascript - 如何在 Vue 和 Snowpack 中配置运行时编译
- sql-server - SQL Server中的while循环子字符串很慢
- bash - 使用 find 排除多种文件类型
- python - 字符串后刮beautifulsoup时不可见
- spring - 在自定义 UserDetailsService 中访问当前 ClientDetails
- vue.js - 有什么方法可以不使用 vue 3 中的挂起进行组合 api 异步?