mirror of https://github.com/postgres/postgres
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
234 lines
3.3 KiB
234 lines
3.3 KiB
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)
|
|
|
|
|