File: selectivity.sql

package info (click to toggle)
pgsphere 1.5.1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 4,084 kB
  • sloc: ansic: 13,927; sql: 6,894; cpp: 853; makefile: 275; perl: 168; yacc: 145; python: 106; lex: 55; xml: 51; sh: 1
file content (36 lines) | stat: -rw-r--r-- 1,753 bytes parent folder | download | duplicates (2)
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
-- 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) %s', do_analyze, query) loop
    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)');
select explain('select * from spoint10k where star <@ scircle(spoint(1,1), .1)');
select explain('select * from spoint10k where star <@ scircle(spoint(1,1), .01)');

select explain('select * from spoint10k where scircle(spoint(1,1), 1) @> star');
select explain('select * from spoint10k where scircle(spoint(1,1), .1) @> star');
select explain('select * from spoint10k where scircle(spoint(1,1), .01) @> star');

select explain('select * from spoint10k where star !<@ scircle(spoint(1,1), 1)');
select explain('select * from spoint10k where star !<@ scircle(spoint(1,1), .1)');
select explain('select * from spoint10k where star !<@ scircle(spoint(1,1), .01)');

select explain('select * from spoint10k where scircle(spoint(1,1), 1) !@> star');
select explain('select * from spoint10k where scircle(spoint(1,1), .1) !@> star');
select explain('select * from spoint10k where scircle(spoint(1,1), .01) !@> star');