У меня есть таблицы
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"
Я пытался использовать для них коррелированные подзапросы, но это дает мне результаты, которых я не ожидаю.
Заранее спасибо!