Очень медленное сканирование кучи растровых изображений в Postgres

У меня есть следующая простая таблица, содержащая данные измерения трафика:

CREATE TABLE "TrafficData"
(
  "RoadID" character varying NOT NULL,
  "DateID" numeric NOT NULL,
  "ExactDateTime" timestamp NOT NULL,
  "CarsSpeed" numeric NOT NULL,
  "CarsCount" numeric NOT NULL
)
CREATE INDEX "RoadDate_Idx" ON "TrafficData" USING btree ("RoadID", "DateID");

Столбец RoadID однозначно определяет дорогу, данные которой записываются, а DateID определяет день года (1..365) данных - в основном округленное представление ExactDateTime.

У меня около 100 000 000 строк; В столбце «RoadID» содержится 1.000 различных значений, а в столбце «DateID» - 365 различных значений.

Затем я выполняю следующий запрос:

SELECT * FROM "TrafficData"
WHERE "RoadID"='Station_1'
AND "DateID">20100610 AND "DateID"<20100618;

На это уходит до трех ошеломляющих секунд, и я не могу понять, ПОЧЕМУ.

EXPLAIN ANALYZE дает мне следующий результат:

Bitmap Heap Scan on "TrafficData"  (cost=104.84..9743.06 rows=2496 width=47) (actual time=35.112..2162.404 rows=2016 loops=1)
  Recheck Cond: ((("RoadID")::text = 'Station_1'::text) AND ("DateID" > 20100610::numeric) AND ("DateID" < 20100618::numeric))
  ->  Bitmap Index Scan on "RoadDate_Idx"  (cost=0.00..104.22 rows=2496 width=0) (actual time=1.637..1.637 rows=2016 loops=1)
        Index Cond: ((("RoadID")::text = 'Station_1'::text) AND ("DateID" > 20100610::numeric) AND ("DateID" < 20100618::numeric))
Total runtime: 2163.985 ms

Мои спецификации:

  • Windows 7
  • Postgres 9.0
  • 4GB RAM

Я был бы очень признателен за любые полезные указатели!

6
задан TroutKing 24 October 2010 в 18:34
поделиться