2000-12-12 04:40:33 +08:00
|
|
|
--
|
|
|
|
-- Test seg datatype
|
|
|
|
--
|
|
|
|
|
2011-02-14 09:06:41 +08:00
|
|
|
CREATE EXTENSION seg;
|
2000-12-12 04:40:33 +08:00
|
|
|
|
2016-11-30 04:05:22 +08:00
|
|
|
-- Check whether any of our opclasses fail amvalidate
|
|
|
|
SELECT amname, opcname
|
|
|
|
FROM pg_opclass opc LEFT JOIN pg_am am ON am.oid = opcmethod
|
|
|
|
WHERE opc.oid >= 16384 AND NOT amvalidate(opc.oid);
|
|
|
|
|
2000-12-12 04:40:33 +08:00
|
|
|
--
|
|
|
|
-- testing the input and output functions
|
|
|
|
--
|
|
|
|
|
|
|
|
-- Any number
|
|
|
|
SELECT '1'::seg AS seg;
|
|
|
|
SELECT '-1'::seg AS seg;
|
|
|
|
SELECT '1.0'::seg AS seg;
|
|
|
|
SELECT '-1.0'::seg AS seg;
|
|
|
|
SELECT '1e7'::seg AS seg;
|
|
|
|
SELECT '-1e7'::seg AS seg;
|
|
|
|
SELECT '1.0e7'::seg AS seg;
|
|
|
|
SELECT '-1.0e7'::seg AS seg;
|
|
|
|
SELECT '1e+7'::seg AS seg;
|
|
|
|
SELECT '-1e+7'::seg AS seg;
|
|
|
|
SELECT '1.0e+7'::seg AS seg;
|
|
|
|
SELECT '-1.0e+7'::seg AS seg;
|
|
|
|
SELECT '1e-7'::seg AS seg;
|
|
|
|
SELECT '-1e-7'::seg AS seg;
|
|
|
|
SELECT '1.0e-7'::seg AS seg;
|
|
|
|
SELECT '-1.0e-7'::seg AS seg;
|
|
|
|
SELECT '2e-6'::seg AS seg;
|
|
|
|
SELECT '2e-5'::seg AS seg;
|
|
|
|
SELECT '2e-4'::seg AS seg;
|
|
|
|
SELECT '2e-3'::seg AS seg;
|
|
|
|
SELECT '2e-2'::seg AS seg;
|
|
|
|
SELECT '2e-1'::seg AS seg;
|
|
|
|
SELECT '2e-0'::seg AS seg;
|
|
|
|
SELECT '2e+0'::seg AS seg;
|
|
|
|
SELECT '2e+1'::seg AS seg;
|
|
|
|
SELECT '2e+2'::seg AS seg;
|
|
|
|
SELECT '2e+3'::seg AS seg;
|
|
|
|
SELECT '2e+4'::seg AS seg;
|
|
|
|
SELECT '2e+5'::seg AS seg;
|
|
|
|
SELECT '2e+6'::seg AS seg;
|
|
|
|
|
|
|
|
|
|
|
|
-- Significant digits preserved
|
|
|
|
SELECT '1'::seg AS seg;
|
|
|
|
SELECT '1.0'::seg AS seg;
|
|
|
|
SELECT '1.00'::seg AS seg;
|
|
|
|
SELECT '1.000'::seg AS seg;
|
|
|
|
SELECT '1.0000'::seg AS seg;
|
|
|
|
SELECT '1.00000'::seg AS seg;
|
|
|
|
SELECT '1.000000'::seg AS seg;
|
|
|
|
SELECT '0.000000120'::seg AS seg;
|
|
|
|
SELECT '3.400e5'::seg AS seg;
|
|
|
|
|
|
|
|
-- Digits truncated
|
|
|
|
SELECT '12.34567890123456'::seg AS seg;
|
|
|
|
|
|
|
|
-- Numbers with certainty indicators
|
|
|
|
SELECT '~6.5'::seg AS seg;
|
|
|
|
SELECT '<6.5'::seg AS seg;
|
|
|
|
SELECT '>6.5'::seg AS seg;
|
|
|
|
SELECT '~ 6.5'::seg AS seg;
|
|
|
|
SELECT '< 6.5'::seg AS seg;
|
|
|
|
SELECT '> 6.5'::seg AS seg;
|
|
|
|
|
|
|
|
-- Open intervals
|
|
|
|
SELECT '0..'::seg AS seg;
|
|
|
|
SELECT '0...'::seg AS seg;
|
|
|
|
SELECT '0 ..'::seg AS seg;
|
|
|
|
SELECT '0 ...'::seg AS seg;
|
|
|
|
SELECT '..0'::seg AS seg;
|
|
|
|
SELECT '...0'::seg AS seg;
|
|
|
|
SELECT '.. 0'::seg AS seg;
|
|
|
|
SELECT '... 0'::seg AS seg;
|
|
|
|
|
|
|
|
-- Finite intervals
|
|
|
|
SELECT '0 .. 1'::seg AS seg;
|
|
|
|
SELECT '-1 .. 0'::seg AS seg;
|
|
|
|
SELECT '-1 .. 1'::seg AS seg;
|
|
|
|
|
|
|
|
-- (+/-) intervals
|
|
|
|
SELECT '0(+-)1'::seg AS seg;
|
|
|
|
SELECT '0(+-)1.0'::seg AS seg;
|
|
|
|
SELECT '1.0(+-)0.005'::seg AS seg;
|
|
|
|
SELECT '101(+-)1'::seg AS seg;
|
|
|
|
-- incorrect number of significant digits in 99.0:
|
|
|
|
SELECT '100(+-)1'::seg AS seg;
|
|
|
|
|
|
|
|
-- invalid input
|
|
|
|
SELECT ''::seg AS seg;
|
|
|
|
SELECT 'ABC'::seg AS seg;
|
|
|
|
SELECT '1ABC'::seg AS seg;
|
|
|
|
SELECT '1.'::seg AS seg;
|
|
|
|
SELECT '1.....'::seg AS seg;
|
|
|
|
SELECT '.1'::seg AS seg;
|
|
|
|
SELECT '1..2.'::seg AS seg;
|
|
|
|
SELECT '1 e7'::seg AS seg;
|
|
|
|
SELECT '1e700'::seg AS seg;
|
|
|
|
|
|
|
|
--
|
|
|
|
-- testing the operators
|
|
|
|
--
|
|
|
|
|
|
|
|
-- equality/inequality:
|
|
|
|
--
|
|
|
|
SELECT '24 .. 33.20'::seg = '24 .. 33.20'::seg AS bool;
|
|
|
|
SELECT '24 .. 33.20'::seg = '24 .. 33.21'::seg AS bool;
|
|
|
|
SELECT '24 .. 33.20'::seg != '24 .. 33.20'::seg AS bool;
|
|
|
|
SELECT '24 .. 33.20'::seg != '24 .. 33.21'::seg AS bool;
|
|
|
|
|
|
|
|
-- overlap
|
|
|
|
--
|
|
|
|
SELECT '1'::seg && '1'::seg AS bool;
|
|
|
|
SELECT '1'::seg && '2'::seg AS bool;
|
|
|
|
SELECT '0 ..'::seg && '0 ..'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg && '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '..0'::seg && '0..'::seg AS bool;
|
|
|
|
SELECT '-1 .. 0.1'::seg && '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '-1 .. 0'::seg && '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '-1 .. -0.0001'::seg && '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '0 ..'::seg && '1'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg && '1'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg && '2'::seg AS bool;
|
|
|
|
SELECT '0 .. 2'::seg && '1'::seg AS bool;
|
|
|
|
SELECT '1'::seg && '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '2'::seg && '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '1'::seg && '0 .. 2'::seg AS bool;
|
|
|
|
|
|
|
|
-- overlap on the left
|
|
|
|
--
|
|
|
|
SELECT '1'::seg &< '0'::seg AS bool;
|
|
|
|
SELECT '1'::seg &< '1'::seg AS bool;
|
|
|
|
SELECT '1'::seg &< '2'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg &< '0'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg &< '1'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg &< '2'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg &< '0 .. 0.5'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg &< '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg &< '0 .. 2'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg &< '1 .. 2'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg &< '2 .. 3'::seg AS bool;
|
|
|
|
|
|
|
|
-- overlap on the right
|
|
|
|
--
|
|
|
|
SELECT '0'::seg &> '1'::seg AS bool;
|
|
|
|
SELECT '1'::seg &> '1'::seg AS bool;
|
|
|
|
SELECT '2'::seg &> '1'::seg AS bool;
|
|
|
|
SELECT '0'::seg &> '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '1'::seg &> '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '2'::seg &> '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '0 .. 0.5'::seg &> '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg &> '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '0 .. 2'::seg &> '0 .. 2'::seg AS bool;
|
|
|
|
SELECT '1 .. 2'::seg &> '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '2 .. 3'::seg &> '0 .. 1'::seg AS bool;
|
|
|
|
|
|
|
|
-- left
|
|
|
|
--
|
|
|
|
SELECT '1'::seg << '0'::seg AS bool;
|
|
|
|
SELECT '1'::seg << '1'::seg AS bool;
|
|
|
|
SELECT '1'::seg << '2'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg << '0'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg << '1'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg << '2'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg << '0 .. 0.5'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg << '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg << '0 .. 2'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg << '1 .. 2'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg << '2 .. 3'::seg AS bool;
|
|
|
|
|
|
|
|
-- right
|
|
|
|
--
|
|
|
|
SELECT '0'::seg >> '1'::seg AS bool;
|
|
|
|
SELECT '1'::seg >> '1'::seg AS bool;
|
|
|
|
SELECT '2'::seg >> '1'::seg AS bool;
|
|
|
|
SELECT '0'::seg >> '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '1'::seg >> '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '2'::seg >> '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '0 .. 0.5'::seg >> '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '0 .. 1'::seg >> '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '0 .. 2'::seg >> '0 .. 2'::seg AS bool;
|
|
|
|
SELECT '1 .. 2'::seg >> '0 .. 1'::seg AS bool;
|
|
|
|
SELECT '2 .. 3'::seg >> '0 .. 1'::seg AS bool;
|
|
|
|
|
|
|
|
|
|
|
|
-- "contained in" (the left value belongs within the interval specified in the right value):
|
|
|
|
--
|
2006-09-11 01:36:52 +08:00
|
|
|
SELECT '0'::seg <@ '0'::seg AS bool;
|
|
|
|
SELECT '0'::seg <@ '0 ..'::seg AS bool;
|
|
|
|
SELECT '0'::seg <@ '.. 0'::seg AS bool;
|
|
|
|
SELECT '0'::seg <@ '-1 .. 1'::seg AS bool;
|
|
|
|
SELECT '0'::seg <@ '-1 .. 1'::seg AS bool;
|
|
|
|
SELECT '-1'::seg <@ '-1 .. 1'::seg AS bool;
|
|
|
|
SELECT '1'::seg <@ '-1 .. 1'::seg AS bool;
|
|
|
|
SELECT '-1 .. 1'::seg <@ '-1 .. 1'::seg AS bool;
|
2000-12-12 04:40:33 +08:00
|
|
|
|
|
|
|
-- "contains" (the left value contains the interval specified in the right value):
|
|
|
|
--
|
2006-09-11 01:36:52 +08:00
|
|
|
SELECT '0'::seg @> '0'::seg AS bool;
|
|
|
|
SELECT '0 .. '::seg <@ '0'::seg AS bool;
|
|
|
|
SELECT '.. 0'::seg <@ '0'::seg AS bool;
|
|
|
|
SELECT '-1 .. 1'::seg <@ '0'::seg AS bool;
|
|
|
|
SELECT '0'::seg <@ '-1 .. 1'::seg AS bool;
|
|
|
|
SELECT '-1'::seg <@ '-1 .. 1'::seg AS bool;
|
|
|
|
SELECT '1'::seg <@ '-1 .. 1'::seg AS bool;
|
2000-12-12 04:40:33 +08:00
|
|
|
|
|
|
|
-- Load some example data and build the index
|
2010-11-24 04:27:50 +08:00
|
|
|
--
|
2000-12-12 04:40:33 +08:00
|
|
|
CREATE TABLE test_seg (s seg);
|
|
|
|
|
|
|
|
\copy test_seg from 'data/test_seg.data'
|
|
|
|
|
|
|
|
CREATE INDEX test_seg_ix ON test_seg USING gist (s);
|
Support index-only scans in contrib/cube and contrib/seg GiST indexes.
To do this, we only have to remove the compress and decompress support
functions, which have never done anything more than detoasting.
In the wake of commit d3a4f89d8, this results in automatically enabling
index-only scans, since the core code will now know that the stored
representation is the same as the original data (up to detoasting).
The only exciting part of this is that ALTER OPERATOR FAMILY lacks
a way to drop a support function that was declared as being part of
an opclass rather than being loose in the family. For the moment,
we'll hack our way to a solution with a manual update of the pg_depend
entry type, which is what distinguishes the two cases. Perhaps
someday it'll be worth providing a cleaner way to do that, but for
now it seems like a very niche problem.
Note that the underlying C functions remain, to support use of the shared
libraries with older versions of the modules' SQL declarations. Someday
we may be able to remove them, but not soon.
Andrey Borodin, reviewed by me
Discussion: https://postgr.es/m/D0F53A05-4F4A-4DEC-8339-3C069FA0EE11@yandex-team.ru
2017-11-21 09:25:18 +08:00
|
|
|
|
2021-06-08 02:52:42 +08:00
|
|
|
SET enable_indexscan = false;
|
Support index-only scans in contrib/cube and contrib/seg GiST indexes.
To do this, we only have to remove the compress and decompress support
functions, which have never done anything more than detoasting.
In the wake of commit d3a4f89d8, this results in automatically enabling
index-only scans, since the core code will now know that the stored
representation is the same as the original data (up to detoasting).
The only exciting part of this is that ALTER OPERATOR FAMILY lacks
a way to drop a support function that was declared as being part of
an opclass rather than being loose in the family. For the moment,
we'll hack our way to a solution with a manual update of the pg_depend
entry type, which is what distinguishes the two cases. Perhaps
someday it'll be worth providing a cleaner way to do that, but for
now it seems like a very niche problem.
Note that the underlying C functions remain, to support use of the shared
libraries with older versions of the modules' SQL declarations. Someday
we may be able to remove them, but not soon.
Andrey Borodin, reviewed by me
Discussion: https://postgr.es/m/D0F53A05-4F4A-4DEC-8339-3C069FA0EE11@yandex-team.ru
2017-11-21 09:25:18 +08:00
|
|
|
EXPLAIN (COSTS OFF)
|
|
|
|
SELECT count(*) FROM test_seg WHERE s @> '11..11.3';
|
|
|
|
SELECT count(*) FROM test_seg WHERE s @> '11..11.3';
|
2021-06-08 02:52:42 +08:00
|
|
|
RESET enable_indexscan;
|
Support index-only scans in contrib/cube and contrib/seg GiST indexes.
To do this, we only have to remove the compress and decompress support
functions, which have never done anything more than detoasting.
In the wake of commit d3a4f89d8, this results in automatically enabling
index-only scans, since the core code will now know that the stored
representation is the same as the original data (up to detoasting).
The only exciting part of this is that ALTER OPERATOR FAMILY lacks
a way to drop a support function that was declared as being part of
an opclass rather than being loose in the family. For the moment,
we'll hack our way to a solution with a manual update of the pg_depend
entry type, which is what distinguishes the two cases. Perhaps
someday it'll be worth providing a cleaner way to do that, but for
now it seems like a very niche problem.
Note that the underlying C functions remain, to support use of the shared
libraries with older versions of the modules' SQL declarations. Someday
we may be able to remove them, but not soon.
Andrey Borodin, reviewed by me
Discussion: https://postgr.es/m/D0F53A05-4F4A-4DEC-8339-3C069FA0EE11@yandex-team.ru
2017-11-21 09:25:18 +08:00
|
|
|
|
|
|
|
SET enable_bitmapscan = false;
|
|
|
|
EXPLAIN (COSTS OFF)
|
|
|
|
SELECT count(*) FROM test_seg WHERE s @> '11..11.3';
|
2006-09-11 01:36:52 +08:00
|
|
|
SELECT count(*) FROM test_seg WHERE s @> '11..11.3';
|
Support index-only scans in contrib/cube and contrib/seg GiST indexes.
To do this, we only have to remove the compress and decompress support
functions, which have never done anything more than detoasting.
In the wake of commit d3a4f89d8, this results in automatically enabling
index-only scans, since the core code will now know that the stored
representation is the same as the original data (up to detoasting).
The only exciting part of this is that ALTER OPERATOR FAMILY lacks
a way to drop a support function that was declared as being part of
an opclass rather than being loose in the family. For the moment,
we'll hack our way to a solution with a manual update of the pg_depend
entry type, which is what distinguishes the two cases. Perhaps
someday it'll be worth providing a cleaner way to do that, but for
now it seems like a very niche problem.
Note that the underlying C functions remain, to support use of the shared
libraries with older versions of the modules' SQL declarations. Someday
we may be able to remove them, but not soon.
Andrey Borodin, reviewed by me
Discussion: https://postgr.es/m/D0F53A05-4F4A-4DEC-8339-3C069FA0EE11@yandex-team.ru
2017-11-21 09:25:18 +08:00
|
|
|
RESET enable_bitmapscan;
|
2000-12-12 04:40:33 +08:00
|
|
|
|
2010-11-24 04:27:50 +08:00
|
|
|
-- Test sorting
|
2006-09-11 01:36:52 +08:00
|
|
|
SELECT * FROM test_seg WHERE s @> '11..11.3' GROUP BY s;
|
2008-04-19 02:43:09 +08:00
|
|
|
|
|
|
|
-- Test functions
|
|
|
|
SELECT seg_lower(s), seg_center(s), seg_upper(s)
|
|
|
|
FROM test_seg WHERE s @> '11.2..11.3' OR s IS NULL ORDER BY s;
|