File: selectivity.out

package info (click to toggle)
pgsphere 1.5.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 4,220 kB
  • sloc: ansic: 13,926; sql: 6,895; cpp: 853; makefile: 278; perl: 168; yacc: 145; python: 106; lex: 55; xml: 51; sh: 1
file content (125 lines) | stat: -rw-r--r-- 6,515 bytes parent folder | download
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
-- test selectivity estimator functions
create table spoint10k (star spoint);
insert into spoint10k select spoint(i, i*i) from generate_series(1, 10000) g(i);
create index on spoint10k using gist (star);
analyze spoint10k;
-- "explain analyze" wrapper that removes 'cost=...' since it varies across architectures
-- (we can't use "costs off" since that also removes the estimated row count)
create or replace function explain(query text, do_analyze text default 'true') returns setof text language plpgsql as $$
declare
  line text;
begin
  for line in execute format('explain (analyze %s, timing off, summary off, buffers off) %s', do_analyze, query) loop
    continue when (line ~ ' +Index Searches: .*');
    return next regexp_replace(line, 'cost=\S+ ', '');
  end loop;
  return;
end;
$$;
-- <@ operator selectivity
select explain('select * from spoint10k where star <@ scircle(spoint(1,1), 1)');
                                            explain                                            
-----------------------------------------------------------------------------------------------
 Bitmap Heap Scan on spoint10k  (rows=2298 width=16) (actual rows=3009 loops=1)
   Recheck Cond: (star <@ '<(1 , 1) , 1>'::scircle)
   Rows Removed by Index Recheck: 1560
   Heap Blocks: exact=55
   ->  Bitmap Index Scan on spoint10k_star_idx  (rows=2298 width=0) (actual rows=4569 loops=1)
         Index Cond: (star <@ '<(1 , 1) , 1>'::scircle)
(6 rows)

select explain('select * from spoint10k where star <@ scircle(spoint(1,1), .1)');
                                          explain                                          
-------------------------------------------------------------------------------------------
 Bitmap Heap Scan on spoint10k  (rows=25 width=16) (actual rows=29 loops=1)
   Recheck Cond: (star <@ '<(1 , 1) , 0.1>'::scircle)
   Rows Removed by Index Recheck: 19
   Heap Blocks: exact=32
   ->  Bitmap Index Scan on spoint10k_star_idx  (rows=25 width=0) (actual rows=48 loops=1)
         Index Cond: (star <@ '<(1 , 1) , 0.1>'::scircle)
(6 rows)

select explain('select * from spoint10k where star <@ scircle(spoint(1,1), .01)');
                                           explain                                           
---------------------------------------------------------------------------------------------
 Index Scan using spoint10k_star_idx on spoint10k  (rows=1 width=16) (actual rows=1 loops=1)
   Index Cond: (star <@ '<(1 , 1) , 0.01>'::scircle)
(2 rows)

select explain('select * from spoint10k where scircle(spoint(1,1), 1) @> star');
                                            explain                                            
-----------------------------------------------------------------------------------------------
 Bitmap Heap Scan on spoint10k  (rows=2298 width=16) (actual rows=3009 loops=1)
   Recheck Cond: ('<(1 , 1) , 1>'::scircle @> star)
   Rows Removed by Index Recheck: 1560
   Heap Blocks: exact=55
   ->  Bitmap Index Scan on spoint10k_star_idx  (rows=2298 width=0) (actual rows=4569 loops=1)
         Index Cond: (star <@ '<(1 , 1) , 1>'::scircle)
(6 rows)

select explain('select * from spoint10k where scircle(spoint(1,1), .1) @> star');
                                          explain                                          
-------------------------------------------------------------------------------------------
 Bitmap Heap Scan on spoint10k  (rows=25 width=16) (actual rows=29 loops=1)
   Recheck Cond: ('<(1 , 1) , 0.1>'::scircle @> star)
   Rows Removed by Index Recheck: 19
   Heap Blocks: exact=32
   ->  Bitmap Index Scan on spoint10k_star_idx  (rows=25 width=0) (actual rows=48 loops=1)
         Index Cond: (star <@ '<(1 , 1) , 0.1>'::scircle)
(6 rows)

select explain('select * from spoint10k where scircle(spoint(1,1), .01) @> star');
                                           explain                                           
---------------------------------------------------------------------------------------------
 Index Scan using spoint10k_star_idx on spoint10k  (rows=1 width=16) (actual rows=1 loops=1)
   Index Cond: (star <@ '<(1 , 1) , 0.01>'::scircle)
(2 rows)

select explain('select * from spoint10k where star !<@ scircle(spoint(1,1), 1)');
                                explain                                 
------------------------------------------------------------------------
 Seq Scan on spoint10k  (rows=7702 width=16) (actual rows=6991 loops=1)
   Filter: (star !<@ '<(1 , 1) , 1>'::scircle)
   Rows Removed by Filter: 3009
(3 rows)

select explain('select * from spoint10k where star !<@ scircle(spoint(1,1), .1)');
                                explain                                 
------------------------------------------------------------------------
 Seq Scan on spoint10k  (rows=9975 width=16) (actual rows=9971 loops=1)
   Filter: (star !<@ '<(1 , 1) , 0.1>'::scircle)
   Rows Removed by Filter: 29
(3 rows)

select explain('select * from spoint10k where star !<@ scircle(spoint(1,1), .01)');
                                 explain                                 
-------------------------------------------------------------------------
 Seq Scan on spoint10k  (rows=10000 width=16) (actual rows=9999 loops=1)
   Filter: (star !<@ '<(1 , 1) , 0.01>'::scircle)
   Rows Removed by Filter: 1
(3 rows)

select explain('select * from spoint10k where scircle(spoint(1,1), 1) !@> star');
                                explain                                 
------------------------------------------------------------------------
 Seq Scan on spoint10k  (rows=7702 width=16) (actual rows=6991 loops=1)
   Filter: ('<(1 , 1) , 1>'::scircle !@> star)
   Rows Removed by Filter: 3009
(3 rows)

select explain('select * from spoint10k where scircle(spoint(1,1), .1) !@> star');
                                explain                                 
------------------------------------------------------------------------
 Seq Scan on spoint10k  (rows=9975 width=16) (actual rows=9971 loops=1)
   Filter: ('<(1 , 1) , 0.1>'::scircle !@> star)
   Rows Removed by Filter: 29
(3 rows)

select explain('select * from spoint10k where scircle(spoint(1,1), .01) !@> star');
                                 explain                                 
-------------------------------------------------------------------------
 Seq Scan on spoint10k  (rows=10000 width=16) (actual rows=9999 loops=1)
   Filter: ('<(1 , 1) , 0.01>'::scircle !@> star)
   Rows Removed by Filter: 1
(3 rows)