PostgreSQL SELECT слишком медленный - PullRequest
0 голосов
/ 26 февраля 2019

Я ищу идею для оптимизации моего запроса.

В настоящее время у меня есть таблица из 4M строк, я хочу получить только последние 1000 строк ссылки:

SELECT * 
FROM customers_material_events 
WHERE reference = 'XXXXXX' 
ORDER BY date DESC 
LIMIT 1000;

Это план выполнения:

Limit  (cost=12512155.48..12512272.15 rows=1000 width=6807) (actual time=8953.545..9013.658 rows=1000 loops=1)
   Buffers: shared hit=16153 read=30342
   ->  Gather Merge  (cost=12512155.48..12840015.90 rows=2810036 width=6807) (actual time=8953.543..9013.613 rows=1000 loops=1)
         Workers Planned: 2
         Workers Launched: 2
         Buffers: shared hit=16153 read=30342
         ->  Sort  (cost=12511155.46..12514668.00 rows=1405018 width=6807) (actual time=8865.186..8865.208 rows=632 loops=3)
               Sort Key: date DESC
               Sort Method: top-N heapsort  Memory: 330kB
               Worker 0:  Sort Method: top-N heapsort  Memory: 328kB
               Worker 1:  Sort Method: top-N heapsort  Memory: 330kB
               Buffers: shared hit=16153 read=30342
               ->  Parallel Seq Scan on customers_material_events  (cost=0.00..64165.96 rows=1405018 width=6807) (actual time=0.064..944.029 rows=1117807 loops=3)
                     Filter: ((reference)::text = 'FFFEEE'::text)
                     Rows Removed by Filter: 17188
                     Buffers: shared hit=16091 read=30342
 Planning Time: 0.189 ms
 Execution Time: 9013.834 ms
(18 rows)

Я вижу, что время выполнения очень, очень медленное ...

1 Ответ

0 голосов
/ 26 февраля 2019

Идеальный индекс для этого запроса:

CREATE INDEX ON customers_material_events (reference, date);

Это позволит вам быстро найти значения для определенного reference, автоматически упорядоченного по date, поэтому дополнительный шаг сортировки не выполняется.необходимо.

...