mirror of
https://github.com/postgres/postgres.git
synced 2025-07-08 11:42:09 +03:00
Add cross-type comparisons to contrib/btree_gin.
Extend the infrastructure in btree_gin.c to permit cross-type operators, and add the code to support them for the int2, int4, and int8 opclasses. (To keep this patch digestible, I left the other datatypes for a separate patch.) This improves the usability of btree_gin indexes by allowing them to support the same set of queries that a regular btree index does. Author: Tom Lane <tgl@sss.pgh.pa.us> Reviewed-by: Arseniy Mukhin <arseniy.mukhin.dev@gmail.com> Discussion: https://postgr.es/m/262624.1738460652@sss.pgh.pa.us
This commit is contained in:
@ -13,3 +13,38 @@ SELECT * FROM test_int2 WHERE i<=1::int2 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i=1::int2 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i>=1::int2 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i>1::int2 ORDER BY i;
|
||||
|
||||
explain (costs off)
|
||||
SELECT * FROM test_int2 WHERE i<1::int4 ORDER BY i;
|
||||
|
||||
SELECT * FROM test_int2 WHERE i<1::int4 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i<=1::int4 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i=1::int4 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i>=1::int4 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i>1::int4 ORDER BY i;
|
||||
|
||||
explain (costs off)
|
||||
SELECT * FROM test_int2 WHERE i<1::int8 ORDER BY i;
|
||||
|
||||
SELECT * FROM test_int2 WHERE i<1::int8 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i<=1::int8 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i=1::int8 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i>=1::int8 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i>1::int8 ORDER BY i;
|
||||
|
||||
-- Check endpoint and out-of-range cases
|
||||
|
||||
INSERT INTO test_int2 VALUES ((-32768)::int2),(32767);
|
||||
SELECT gin_clean_pending_list('idx_int2');
|
||||
|
||||
SELECT * FROM test_int2 WHERE i<(-32769)::int4 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i<=(-32769)::int4 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i=(-32769)::int4 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i>=(-32769)::int4 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i>(-32769)::int4 ORDER BY i;
|
||||
|
||||
SELECT * FROM test_int2 WHERE i<32768::int4 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i<=32768::int4 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i=32768::int4 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i>=32768::int4 ORDER BY i;
|
||||
SELECT * FROM test_int2 WHERE i>32768::int4 ORDER BY i;
|
||||
|
@ -13,3 +13,21 @@ SELECT * FROM test_int4 WHERE i<=1::int4 ORDER BY i;
|
||||
SELECT * FROM test_int4 WHERE i=1::int4 ORDER BY i;
|
||||
SELECT * FROM test_int4 WHERE i>=1::int4 ORDER BY i;
|
||||
SELECT * FROM test_int4 WHERE i>1::int4 ORDER BY i;
|
||||
|
||||
explain (costs off)
|
||||
SELECT * FROM test_int4 WHERE i<1::int2 ORDER BY i;
|
||||
|
||||
SELECT * FROM test_int4 WHERE i<1::int2 ORDER BY i;
|
||||
SELECT * FROM test_int4 WHERE i<=1::int2 ORDER BY i;
|
||||
SELECT * FROM test_int4 WHERE i=1::int2 ORDER BY i;
|
||||
SELECT * FROM test_int4 WHERE i>=1::int2 ORDER BY i;
|
||||
SELECT * FROM test_int4 WHERE i>1::int2 ORDER BY i;
|
||||
|
||||
explain (costs off)
|
||||
SELECT * FROM test_int4 WHERE i<1::int8 ORDER BY i;
|
||||
|
||||
SELECT * FROM test_int4 WHERE i<1::int8 ORDER BY i;
|
||||
SELECT * FROM test_int4 WHERE i<=1::int8 ORDER BY i;
|
||||
SELECT * FROM test_int4 WHERE i=1::int8 ORDER BY i;
|
||||
SELECT * FROM test_int4 WHERE i>=1::int8 ORDER BY i;
|
||||
SELECT * FROM test_int4 WHERE i>1::int8 ORDER BY i;
|
||||
|
@ -13,3 +13,21 @@ SELECT * FROM test_int8 WHERE i<=1::int8 ORDER BY i;
|
||||
SELECT * FROM test_int8 WHERE i=1::int8 ORDER BY i;
|
||||
SELECT * FROM test_int8 WHERE i>=1::int8 ORDER BY i;
|
||||
SELECT * FROM test_int8 WHERE i>1::int8 ORDER BY i;
|
||||
|
||||
explain (costs off)
|
||||
SELECT * FROM test_int8 WHERE i<1::int2 ORDER BY i;
|
||||
|
||||
SELECT * FROM test_int8 WHERE i<1::int2 ORDER BY i;
|
||||
SELECT * FROM test_int8 WHERE i<=1::int2 ORDER BY i;
|
||||
SELECT * FROM test_int8 WHERE i=1::int2 ORDER BY i;
|
||||
SELECT * FROM test_int8 WHERE i>=1::int2 ORDER BY i;
|
||||
SELECT * FROM test_int8 WHERE i>1::int2 ORDER BY i;
|
||||
|
||||
explain (costs off)
|
||||
SELECT * FROM test_int8 WHERE i<1::int4 ORDER BY i;
|
||||
|
||||
SELECT * FROM test_int8 WHERE i<1::int4 ORDER BY i;
|
||||
SELECT * FROM test_int8 WHERE i<=1::int4 ORDER BY i;
|
||||
SELECT * FROM test_int8 WHERE i=1::int4 ORDER BY i;
|
||||
SELECT * FROM test_int8 WHERE i>=1::int4 ORDER BY i;
|
||||
SELECT * FROM test_int8 WHERE i>1::int4 ORDER BY i;
|
||||
|
Reference in New Issue
Block a user