Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> При update таблицы идет seq scan 
:(
    Опции темы
polin11
Дата 13.10.2021, 14:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 93
Регистрация: 6.6.2015

Репутация: нет
Всего: нет



Использую Postgresql, есть запрос в котором нужно обновить таблицу новыми значениями, а тех записей которых нет,
вернуть.
Приблизительно запрос выглядит так:

Код

WITH ...(
.
.
.),
documents AS (
   SELECT
       ad."DocId"
       d."EndDate",
       d."Responsible",
       d."Account"
   FROM documents_raw d
   LEFT JOIN "ActualDocument" ad
   ON (d."Account"=ad."Account" AND d."Responsible"=ad."Responsible")     
)
documents_upd AS(
   UPDATE "ActualDocument"
   SET "ActualDocument"."EndDate" = documents."EndDate"
   FROM documents
   WHERE "ActualDocument"."DocId"= documents."DocId" 
)
SELECT *
FROM documents_upd
WHERE "DocId" IS NULL




Проблема возникает при обновлении в CTE documents_upd
в плане Hash Join идет Seq Scan по таблице "ActualDocument".

Хочется чтобы использовался индекс по первичному ключу "DocId" таблицы "ActualDocument".
Например когда использую EXISTS или INNER JOIN в CTE, то используется индекс по первичному ключу "DocId"

Код

WITH (...
.
.
.),
documents AS (
   SELECT
       ad."DocId"
       d."EndDate",
       d."Responsible",
       d."Account"
   FROM documents_raw d
   LEFT JOIN "ActualDocument" ad
   ON (d."Account"=ad."Account" AND d."Responsible"=ad."Responsible")     
)
SELECT *
FROM "ActualDocument"
WHERE EXISTS (
SELECT TRUE
FROM documents
WHERE
"ActualDocument"."DocId"= documents."DocId" 
)

PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | PostgreSQL | Следующая тема »


 




[ Время генерации скрипта: 0.1029 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.