mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-12 18:34:36 +08:00
f4cd7102b5
Mostly for completeness, but I believe there are cases to use that in multicolumn GIN indexes. Bump btree_gin module version Author: Matheus Oliveira Reviewed by: Tomas Vondra Discussion: https://www.postgresql.org/message-id/flat/CAJghg4LMJf6Z13fnZD-MBNiGxzd0cA2=F3TDjNkX3eQH58hktQ@mail.gmail.com
98 lines
2.3 KiB
Plaintext
98 lines
2.3 KiB
Plaintext
set enable_seqscan=off;
|
|
CREATE TABLE test_name (
|
|
i name
|
|
);
|
|
INSERT INTO test_name VALUES ('a'),('ab'),('abc'),('abb'),('axy'),('xyz');
|
|
CREATE INDEX idx_name ON test_name USING gin (i);
|
|
SELECT * FROM test_name WHERE i<'abc' ORDER BY i;
|
|
i
|
|
-----
|
|
a
|
|
ab
|
|
abb
|
|
(3 rows)
|
|
|
|
SELECT * FROM test_name WHERE i<='abc' ORDER BY i;
|
|
i
|
|
-----
|
|
a
|
|
ab
|
|
abb
|
|
abc
|
|
(4 rows)
|
|
|
|
SELECT * FROM test_name WHERE i='abc' ORDER BY i;
|
|
i
|
|
-----
|
|
abc
|
|
(1 row)
|
|
|
|
SELECT * FROM test_name WHERE i>='abc' ORDER BY i;
|
|
i
|
|
-----
|
|
abc
|
|
axy
|
|
xyz
|
|
(3 rows)
|
|
|
|
SELECT * FROM test_name WHERE i>'abc' ORDER BY i;
|
|
i
|
|
-----
|
|
axy
|
|
xyz
|
|
(2 rows)
|
|
|
|
EXPLAIN (COSTS OFF) SELECT * FROM test_name WHERE i<'abc' ORDER BY i;
|
|
QUERY PLAN
|
|
---------------------------------------------
|
|
Sort
|
|
Sort Key: i
|
|
-> Bitmap Heap Scan on test_name
|
|
Recheck Cond: (i < 'abc'::name)
|
|
-> Bitmap Index Scan on idx_name
|
|
Index Cond: (i < 'abc'::name)
|
|
(6 rows)
|
|
|
|
EXPLAIN (COSTS OFF) SELECT * FROM test_name WHERE i<='abc' ORDER BY i;
|
|
QUERY PLAN
|
|
----------------------------------------------
|
|
Sort
|
|
Sort Key: i
|
|
-> Bitmap Heap Scan on test_name
|
|
Recheck Cond: (i <= 'abc'::name)
|
|
-> Bitmap Index Scan on idx_name
|
|
Index Cond: (i <= 'abc'::name)
|
|
(6 rows)
|
|
|
|
EXPLAIN (COSTS OFF) SELECT * FROM test_name WHERE i='abc' ORDER BY i;
|
|
QUERY PLAN
|
|
---------------------------------------
|
|
Bitmap Heap Scan on test_name
|
|
Recheck Cond: (i = 'abc'::name)
|
|
-> Bitmap Index Scan on idx_name
|
|
Index Cond: (i = 'abc'::name)
|
|
(4 rows)
|
|
|
|
EXPLAIN (COSTS OFF) SELECT * FROM test_name WHERE i>='abc' ORDER BY i;
|
|
QUERY PLAN
|
|
----------------------------------------------
|
|
Sort
|
|
Sort Key: i
|
|
-> Bitmap Heap Scan on test_name
|
|
Recheck Cond: (i >= 'abc'::name)
|
|
-> Bitmap Index Scan on idx_name
|
|
Index Cond: (i >= 'abc'::name)
|
|
(6 rows)
|
|
|
|
EXPLAIN (COSTS OFF) SELECT * FROM test_name WHERE i>'abc' ORDER BY i;
|
|
QUERY PLAN
|
|
---------------------------------------------
|
|
Sort
|
|
Sort Key: i
|
|
-> Bitmap Heap Scan on test_name
|
|
Recheck Cond: (i > 'abc'::name)
|
|
-> Bitmap Index Scan on idx_name
|
|
Index Cond: (i > 'abc'::name)
|
|
(6 rows)
|
|
|