mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-12 18:34:36 +08:00
8436489c81
This extends GiST's support for nearest-neighbor searches to many of the standard data types. Teodor Sigaev
38 lines
990 B
SQL
38 lines
990 B
SQL
-- 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';
|
|
|
|
SELECT count(*) FROM timetmp WHERE a <= '10:57:11';
|
|
|
|
SELECT count(*) FROM timetmp WHERE a = '10:57:11';
|
|
|
|
SELECT count(*) FROM timetmp WHERE a >= '10:57:11';
|
|
|
|
SELECT count(*) FROM timetmp WHERE a > '10:57:11';
|
|
|
|
SELECT a, a <-> '10:57:11' FROM timetmp ORDER BY a <-> '10:57:11' LIMIT 3;
|
|
|
|
CREATE INDEX timeidx ON timetmp USING gist ( a );
|
|
|
|
SET enable_seqscan=off;
|
|
|
|
SELECT count(*) FROM timetmp WHERE a < '10:57:11'::time;
|
|
|
|
SELECT count(*) FROM timetmp WHERE a <= '10:57:11'::time;
|
|
|
|
SELECT count(*) FROM timetmp WHERE a = '10:57:11'::time;
|
|
|
|
SELECT count(*) FROM timetmp WHERE a >= '10:57:11'::time;
|
|
|
|
SELECT count(*) FROM timetmp WHERE a > '10:57:11'::time;
|
|
|
|
EXPLAIN (COSTS OFF)
|
|
SELECT a, a <-> '10:57:11' FROM timetmp ORDER BY a <-> '10:57:11' LIMIT 3;
|
|
SELECT a, a <-> '10:57:11' FROM timetmp ORDER BY a <-> '10:57:11' LIMIT 3;
|