aboutsummaryrefslogtreecommitdiff
path: root/contrib/btree_gist/sql/bit.sql
blob: 53c67cf77acfe528b50fecc16f527b7089262c56 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
-- bit check

CREATE TABLE bittmp (a bit(33));

\copy bittmp from 'data/bit.data'

SET enable_seqscan=on;

SELECT count(*) FROM bittmp WHERE a <   '011011000100010111011000110000100';

SELECT count(*) FROM bittmp WHERE a <=  '011011000100010111011000110000100';

SELECT count(*) FROM bittmp WHERE a  =  '011011000100010111011000110000100';

SELECT count(*) FROM bittmp WHERE a >=  '011011000100010111011000110000100';

SELECT count(*) FROM bittmp WHERE a >   '011011000100010111011000110000100';

SET client_min_messages = DEBUG1;
CREATE INDEX bitidx ON bittmp USING GIST ( a );
CREATE INDEX bitidx_b ON bittmp USING GIST ( a ) WITH (buffering=on);
DROP INDEX bitidx_b;
RESET client_min_messages;

SET enable_seqscan=off;

SELECT count(*) FROM bittmp WHERE a <   '011011000100010111011000110000100';

SELECT count(*) FROM bittmp WHERE a <=  '011011000100010111011000110000100';

SELECT count(*) FROM bittmp WHERE a  =  '011011000100010111011000110000100';

SELECT count(*) FROM bittmp WHERE a >=  '011011000100010111011000110000100';

SELECT count(*) FROM bittmp WHERE a >   '011011000100010111011000110000100';

-- Test index-only scans
SET enable_bitmapscan=off;
EXPLAIN (COSTS OFF)
SELECT a FROM bittmp WHERE a BETWEEN '1000000' and '1000001';