mirror of
https://git.postgresql.org/git/postgresql.git
synced 2024-08-26 03:27:19 +02:00
9f984ba6d2
Commit 16fa9b2b30
introduced a faster way to build GiST indexes, by
sorting all the data. This commit adds the sortsupport functions needed
to make use of that feature for btree_gist.
Author: Andrey Borodin
Discussion: https://www.postgresql.org/message-id/2F3F7265-0D22-44DB-AD71-8554C743D943@yandex-team.ru
99 lines
2.1 KiB
Plaintext
99 lines
2.1 KiB
Plaintext
-- time check
|
|
CREATE TABLE timetmp (a time);
|
|
\copy timetmp from 'data/time.data'
|
|
SET enable_seqscan=on;
|
|
SELECT count(*) FROM timetmp WHERE a < '10:57:11';
|
|
count
|
|
-------
|
|
251
|
|
(1 row)
|
|
|
|
SELECT count(*) FROM timetmp WHERE a <= '10:57:11';
|
|
count
|
|
-------
|
|
252
|
|
(1 row)
|
|
|
|
SELECT count(*) FROM timetmp WHERE a = '10:57:11';
|
|
count
|
|
-------
|
|
1
|
|
(1 row)
|
|
|
|
SELECT count(*) FROM timetmp WHERE a >= '10:57:11';
|
|
count
|
|
-------
|
|
293
|
|
(1 row)
|
|
|
|
SELECT count(*) FROM timetmp WHERE a > '10:57:11';
|
|
count
|
|
-------
|
|
292
|
|
(1 row)
|
|
|
|
SELECT a, a <-> '10:57:11' FROM timetmp ORDER BY a <-> '10:57:11' LIMIT 3;
|
|
a | ?column?
|
|
----------+-----------------
|
|
10:57:11 | @ 0
|
|
10:57:10 | @ 1 sec
|
|
10:55:32 | @ 1 min 39 secs
|
|
(3 rows)
|
|
|
|
SET client_min_messages = DEBUG1;
|
|
CREATE INDEX timeidx ON timetmp USING gist ( a );
|
|
DEBUG: building index "timeidx" on table "timetmp" serially
|
|
DEBUG: using sorted GiST build
|
|
CREATE INDEX timeidx_b ON timetmp USING gist ( a ) WITH (buffering=on);
|
|
DEBUG: building index "timeidx_b" on table "timetmp" serially
|
|
DROP INDEX timeidx_b;
|
|
RESET client_min_messages;
|
|
SET enable_seqscan=off;
|
|
SELECT count(*) FROM timetmp WHERE a < '10:57:11'::time;
|
|
count
|
|
-------
|
|
251
|
|
(1 row)
|
|
|
|
SELECT count(*) FROM timetmp WHERE a <= '10:57:11'::time;
|
|
count
|
|
-------
|
|
252
|
|
(1 row)
|
|
|
|
SELECT count(*) FROM timetmp WHERE a = '10:57:11'::time;
|
|
count
|
|
-------
|
|
1
|
|
(1 row)
|
|
|
|
SELECT count(*) FROM timetmp WHERE a >= '10:57:11'::time;
|
|
count
|
|
-------
|
|
293
|
|
(1 row)
|
|
|
|
SELECT count(*) FROM timetmp WHERE a > '10:57:11'::time;
|
|
count
|
|
-------
|
|
292
|
|
(1 row)
|
|
|
|
EXPLAIN (COSTS OFF)
|
|
SELECT a, a <-> '10:57:11' FROM timetmp ORDER BY a <-> '10:57:11' LIMIT 3;
|
|
QUERY PLAN
|
|
--------------------------------------------------------------
|
|
Limit
|
|
-> Index Only Scan using timeidx on timetmp
|
|
Order By: (a <-> '10:57:11'::time without time zone)
|
|
(3 rows)
|
|
|
|
SELECT a, a <-> '10:57:11' FROM timetmp ORDER BY a <-> '10:57:11' LIMIT 3;
|
|
a | ?column?
|
|
----------+-----------------
|
|
10:57:11 | @ 0
|
|
10:57:10 | @ 1 sec
|
|
10:55:32 | @ 1 min 39 secs
|
|
(3 rows)
|
|
|