mirror of
https://github.com/postgres/postgres.git
synced 2025-10-19 15:49:24 +03:00
Using the just-added infrastructure, extend btree_gin to support cross-type operators in its other opclasses. All of the cross-type comparison operators supported by the core btree opclasses for these datatypes are now available for btree_gin indexes as well. 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
95 lines
1.6 KiB
Plaintext
95 lines
1.6 KiB
Plaintext
set enable_seqscan=off;
|
|
CREATE TABLE test_text (
|
|
i text
|
|
);
|
|
INSERT INTO test_text VALUES ('a'),('ab'),('abc'),('abb'),('axy'),('xyz');
|
|
CREATE INDEX idx_text ON test_text USING gin (i);
|
|
SELECT * FROM test_text WHERE i<'abc' ORDER BY i;
|
|
i
|
|
-----
|
|
a
|
|
ab
|
|
abb
|
|
(3 rows)
|
|
|
|
SELECT * FROM test_text WHERE i<='abc' ORDER BY i;
|
|
i
|
|
-----
|
|
a
|
|
ab
|
|
abb
|
|
abc
|
|
(4 rows)
|
|
|
|
SELECT * FROM test_text WHERE i='abc' ORDER BY i;
|
|
i
|
|
-----
|
|
abc
|
|
(1 row)
|
|
|
|
SELECT * FROM test_text WHERE i>='abc' ORDER BY i;
|
|
i
|
|
-----
|
|
abc
|
|
axy
|
|
xyz
|
|
(3 rows)
|
|
|
|
SELECT * FROM test_text WHERE i>'abc' ORDER BY i;
|
|
i
|
|
-----
|
|
axy
|
|
xyz
|
|
(2 rows)
|
|
|
|
explain (costs off)
|
|
SELECT * FROM test_text WHERE i<'abc'::name COLLATE "default" ORDER BY i;
|
|
QUERY PLAN
|
|
---------------------------------------------------------------
|
|
Sort
|
|
Sort Key: i
|
|
-> Bitmap Heap Scan on test_text
|
|
Recheck Cond: (i < 'abc'::name COLLATE "default")
|
|
-> Bitmap Index Scan on idx_text
|
|
Index Cond: (i < 'abc'::name COLLATE "default")
|
|
(6 rows)
|
|
|
|
SELECT * FROM test_text WHERE i<'abc'::name COLLATE "default" ORDER BY i;
|
|
i
|
|
-----
|
|
a
|
|
ab
|
|
abb
|
|
(3 rows)
|
|
|
|
SELECT * FROM test_text WHERE i<='abc'::name COLLATE "default" ORDER BY i;
|
|
i
|
|
-----
|
|
a
|
|
ab
|
|
abb
|
|
abc
|
|
(4 rows)
|
|
|
|
SELECT * FROM test_text WHERE i='abc'::name COLLATE "default" ORDER BY i;
|
|
i
|
|
-----
|
|
abc
|
|
(1 row)
|
|
|
|
SELECT * FROM test_text WHERE i>='abc'::name COLLATE "default" ORDER BY i;
|
|
i
|
|
-----
|
|
abc
|
|
axy
|
|
xyz
|
|
(3 rows)
|
|
|
|
SELECT * FROM test_text WHERE i>'abc'::name COLLATE "default" ORDER BY i;
|
|
i
|
|
-----
|
|
axy
|
|
xyz
|
|
(2 rows)
|
|
|