Re: choosing index to use

Поиск
Список
Период
Сортировка
От PFC
Тема Re: choosing index to use
Дата
Msg-id op.sqvr6yjeth1vuj@localhost
обсуждение исходный текст
Ответ на choosing index to use  ("Ilya A. Kovalenko" <shadow@oganer.net>)
Список pgsql-sql
Try indexing on client, time instead of time, client...
putting the equality condition on the first column of the index can make  
it faster.
Else, analyze, increase your stats, etc...

On Mon, 16 May 2005 13:39:40 +0200, Ilya A. Kovalenko <shadow@oganer.net>  
wrote:

>     Greetings,
>
>   How can I control which indexes will or won't be used by query ?
>
>   I never think, that I'll need something like this.
>
> Short version:
>
>   Simple SELECT query perfomance speeds up (10x-20x) after _removing_
> one of indexes. Because (as EXPLAIN shows), after removing, query
> switches to another index.
>   How to make such without index removing ?
>
>   PostgreSQL 8.0.2, OpenBSD 3.7, i386
> Thank you.
> Ilya A. Kovalenko
> Special EQ SW section
> JSC Oganer-Service
>
> Details:
>
> CREATE TABLE traffic_stat
> (
>   time      timestamptz NOT NULL,
>   client    inet NOT NULL,
>   remote    inet NOT NULL,
>   count_in  int8 NOT NULL,
>   count_out int8 NOT NULL
> ) WITHOUT OIDS;
>
> CREATE INDEX traffic_client_idx
>   ON traffic_stat
>   USING btree
>   (client);
> CREATE INDEX traffic_date_idx
>   ON traffic_stat
>   USING btree
>   ("time");
> CREATE INDEX traffic_remote_idx
>   ON traffic_stat
>   USING btree
>   (remote);
> CREATE INDEX traffic_multy_idx
>   ON traffic_stat
>   USING btree
>   ("time", client, remote);
> CREATE INDEX traffic_date_client_idx
>   ON traffic_stat
>   USING btree
>   ("time", client);
>
> SELECT count(*) FROM traffic_stat;
>
> 135511
>
> Query is:
> SELECT to_char(time, 'DD.MM.YYYY HH24:MI.SS'), remote, count_in,  
> count_out
>   FROM traffic_stat WHERE client = '192.168.xxx.xxx' AND
>   time > '2005-05-16' AND time < '2005-05-16'::date + '1 days'::interval
>   ORDER BY time;
>
> Case 1:
> SELECT ...
>
> Total query runtime: 2643 ms.
> Data retrieval runtime: 20 ms.
> 39 rows retrieved.
>
> EXPLAIN SELECT ...
>
> Index Scan using traffic_date_idx on traffic_stat  (cost=0.00..3.08  
> rows=1 width=35)
>   Index Cond: (("time" > '2005-05-16 00:00:00+08'::timestamp with time  
> zone) AND ("time" < '2005-05-17 00:00:00'::timestamp without time zone))
>   Filter: (client = '192.168.114.31'::inet)
>
> Case 2:
>
> DROP INDEX traffic_date_idx;
>
> SELECT ...
>
> Total query runtime: 290 ms.
> Data retrieval runtime: 20 ms.
> 41 rows retrieved.
>
> EXPLAIN SELECT ...
>
> Index Scan using traffic_date_client_idx on traffic_stat   
> (cost=0.00..4.37 rows=1 width=35)
>   Index Cond: (("time" > '2005-05-16 00:00:00+08'::timestamp with time  
> zone) AND ("time" < '2005-05-17 00:00:00'::timestamp without time zone)  
> AND (client = '192.168.114.31'::inet))
>
>
>
> ---------------------------(end of broadcast)---------------------------
> TIP 8: explain analyze is your friend
>




В списке pgsql-sql по дате отправления:

Предыдущее
От: "Ilya A. Kovalenko"
Дата:
Сообщение: choosing index to use
Следующее
От: David B
Дата:
Сообщение: ORDER BY handling mixed integer and varchar values