1
0
mirror of https://github.com/postgres/postgres.git synced 2025-10-25 13:17:41 +03:00
Files
postgres/contrib/btree_gin/expected/int2.out
Tom Lane e2b64fcef3 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
2025-07-03 16:24:31 -04:00

235 lines
3.3 KiB
Plaintext

set enable_seqscan=off;
CREATE TABLE test_int2 (
i int2
);
INSERT INTO test_int2 VALUES (-2),(-1),(0),(1),(2),(3);
CREATE INDEX idx_int2 ON test_int2 USING gin (i);
SELECT * FROM test_int2 WHERE i<1::int2 ORDER BY i;
i
----
-2
-1
0
(3 rows)
SELECT * FROM test_int2 WHERE i<=1::int2 ORDER BY i;
i
----
-2
-1
0
1
(4 rows)
SELECT * FROM test_int2 WHERE i=1::int2 ORDER BY i;
i
---
1
(1 row)
SELECT * FROM test_int2 WHERE i>=1::int2 ORDER BY i;
i
---
1
2
3
(3 rows)
SELECT * FROM test_int2 WHERE i>1::int2 ORDER BY i;
i
---
2
3
(2 rows)
explain (costs off)
SELECT * FROM test_int2 WHERE i<1::int4 ORDER BY i;
QUERY PLAN
-------------------------------------------
Sort
Sort Key: i
-> Bitmap Heap Scan on test_int2
Recheck Cond: (i < 1)
-> Bitmap Index Scan on idx_int2
Index Cond: (i < 1)
(6 rows)
SELECT * FROM test_int2 WHERE i<1::int4 ORDER BY i;
i
----
-2
-1
0
(3 rows)
SELECT * FROM test_int2 WHERE i<=1::int4 ORDER BY i;
i
----
-2
-1
0
1
(4 rows)
SELECT * FROM test_int2 WHERE i=1::int4 ORDER BY i;
i
---
1
(1 row)
SELECT * FROM test_int2 WHERE i>=1::int4 ORDER BY i;
i
---
1
2
3
(3 rows)
SELECT * FROM test_int2 WHERE i>1::int4 ORDER BY i;
i
---
2
3
(2 rows)
explain (costs off)
SELECT * FROM test_int2 WHERE i<1::int8 ORDER BY i;
QUERY PLAN
---------------------------------------------
Sort
Sort Key: i
-> Bitmap Heap Scan on test_int2
Recheck Cond: (i < '1'::bigint)
-> Bitmap Index Scan on idx_int2
Index Cond: (i < '1'::bigint)
(6 rows)
SELECT * FROM test_int2 WHERE i<1::int8 ORDER BY i;
i
----
-2
-1
0
(3 rows)
SELECT * FROM test_int2 WHERE i<=1::int8 ORDER BY i;
i
----
-2
-1
0
1
(4 rows)
SELECT * FROM test_int2 WHERE i=1::int8 ORDER BY i;
i
---
1
(1 row)
SELECT * FROM test_int2 WHERE i>=1::int8 ORDER BY i;
i
---
1
2
3
(3 rows)
SELECT * FROM test_int2 WHERE i>1::int8 ORDER BY i;
i
---
2
3
(2 rows)
-- Check endpoint and out-of-range cases
INSERT INTO test_int2 VALUES ((-32768)::int2),(32767);
SELECT gin_clean_pending_list('idx_int2');
gin_clean_pending_list
------------------------
1
(1 row)
SELECT * FROM test_int2 WHERE i<(-32769)::int4 ORDER BY i;
i
---
(0 rows)
SELECT * FROM test_int2 WHERE i<=(-32769)::int4 ORDER BY i;
i
---
(0 rows)
SELECT * FROM test_int2 WHERE i=(-32769)::int4 ORDER BY i;
i
---
(0 rows)
SELECT * FROM test_int2 WHERE i>=(-32769)::int4 ORDER BY i;
i
--------
-32768
-2
-1
0
1
2
3
32767
(8 rows)
SELECT * FROM test_int2 WHERE i>(-32769)::int4 ORDER BY i;
i
--------
-32768
-2
-1
0
1
2
3
32767
(8 rows)
SELECT * FROM test_int2 WHERE i<32768::int4 ORDER BY i;
i
--------
-32768
-2
-1
0
1
2
3
32767
(8 rows)
SELECT * FROM test_int2 WHERE i<=32768::int4 ORDER BY i;
i
--------
-32768
-2
-1
0
1
2
3
32767
(8 rows)
SELECT * FROM test_int2 WHERE i=32768::int4 ORDER BY i;
i
---
(0 rows)
SELECT * FROM test_int2 WHERE i>=32768::int4 ORDER BY i;
i
---
(0 rows)
SELECT * FROM test_int2 WHERE i>32768::int4 ORDER BY i;
i
---
(0 rows)