summaryrefslogtreecommitdiff
path: root/contrib/btree_gin/sql/interval.sql
diff options
context:
space:
mode:
authorDean Rasheed <dean.a.rasheed@gmail.com>2023-10-29 11:14:34 +0000
committerDean Rasheed <dean.a.rasheed@gmail.com>2023-10-29 11:14:34 +0000
commit35e6a5c20d453921efa24342effb648cad3573ec (patch)
treed58825f91da3ab57f5b212847bfb8109a90f778f /contrib/btree_gin/sql/interval.sql
parentb7684473d74a7555e3fb7d1a492ef50d24bfce31 (diff)
btree_gin: Fix calculation of leftmost interval value.
Formerly, the value computed by leftmostvalue_interval() was a long way short of the minimum possible interval value. As a result, an index scan on a GIN index on an interval column with < or <= operators would miss large negative interval values. Fix by setting all fields of the leftmost interval to their minimum values, ensuring that the result is less than any other possible interval. Since this only affects index searches, no index rebuild is necessary. Back-patch to all supported branches. Dean Rasheed, reviewed by Heikki Linnakangas. Discussion: https://postgr.es/m/CAEZATCV80%2BgOfF8ehNUUfaKBZgZMDfCfL-g1HhWGb6kC3rpDfw%40mail.gmail.com
Diffstat (limited to 'contrib/btree_gin/sql/interval.sql')
-rw-r--r--contrib/btree_gin/sql/interval.sql4
1 files changed, 3 insertions, 1 deletions
diff --git a/contrib/btree_gin/sql/interval.sql b/contrib/btree_gin/sql/interval.sql
index e3851587833..7a2f3ac0d85 100644
--- a/contrib/btree_gin/sql/interval.sql
+++ b/contrib/btree_gin/sql/interval.sql
@@ -5,12 +5,14 @@ CREATE TABLE test_interval (
);
INSERT INTO test_interval VALUES
+ ( '-178000000 years' ),
( '03:55:08' ),
( '04:55:08' ),
( '05:55:08' ),
( '08:55:08' ),
( '09:55:08' ),
- ( '10:55:08' )
+ ( '10:55:08' ),
+ ( '178000000 years' )
;
CREATE INDEX idx_interval ON test_interval USING gin (i);