Commit 598ea2c3 authored by Tom Lane's avatar Tom Lane

Finish repairing 6.5's problems with r-tree indexes: create appropriate

selectivity functions and make the r-tree operators use them.  The
estimation functions themselves are just stubs, unfortunately, but
perhaps someday someone will make them compute realistic estimates.
Change pg_am so that the optimizer can reliably tell the difference
between ordered and unordered indexes --- before it would think that
an r-tree index can be scanned in '<<' order, which is not right AFAIK.
Repair broken negator links for network_sup and related ops.
Initdb forced.  This might be my last initdb force for 7.0 ... hope so
anyway ...
parent cf880a61
.\" This is -*-nroff-*- .\" This is -*-nroff-*-
.\" XXX standard disclaimer belongs here.... .\" XXX standard disclaimer belongs here....
.\" $Header: /cvsroot/pgsql/doc/src/sgml/catalogs.sgml,v 2.4 2000/02/06 05:09:31 momjian Exp $ .\" $Header: /cvsroot/pgsql/doc/src/sgml/catalogs.sgml,v 2.5 2000/02/17 03:39:39 tgl Exp $
.TH "SYSTEM CATALOGS" INTRO 03/13/94 PostgreSQL PostgreSQL .TH "SYSTEM CATALOGS" INTRO 03/13/94 PostgreSQL PostgreSQL
.SH "Section 7 - System Catalogs" .SH "Section 7 - System Catalogs"
.de LS .de LS
...@@ -108,38 +108,37 @@ pg_aggregate ...@@ -108,38 +108,37 @@ pg_aggregate
.fi .fi
.nf M .nf M
pg_am pg_am
NameData amname /* access method name */ NameData amname /* access method name */
oid amowner /* usesysid of creator */ oid amowner /* usesysid of creator */
char amkind /* - deprecated */ int2 amstrategies /* total NUMBER of strategies by which
/* originally: we can traverse/search this AM */
h=hashed int2 amsupport /* total NUMBER of support functions
o=ordered that this AM uses */
s=special */ int2 amorderstrategy /* if this AM has a sort order, the
int2 amstrategies /* total NUMBER of strategies by which * strategy number of the sort operator.
we can traverse/search this AM */ * Zero if AM is not ordered.
int2 amsupport /* total NUMBER of support functions */
that this AM uses */ regproc amgettuple /* "next valid tuple" function */
regproc amgettuple /* "next valid tuple" function */ regproc aminsert /* "insert this tuple" function */
regproc aminsert /* "insert this tuple" function */ regproc amdelete /* "delete this tuple" function */
regproc amdelete /* "delete this tuple" function */ regproc amgetattr /* - deprecated */
regproc amgetattr /* - deprecated */ regproc amsetlock /* - deprecated */
regproc amsetlock /* - deprecated */ regproc amsettid /* - deprecated */
regproc amsettid /* - deprecated */ regproc amfreetuple /* - deprecated */
regproc amfreetuple /* - deprecated */ regproc ambeginscan /* "start new scan" function */
regproc ambeginscan /* "start new scan" function */ regproc amrescan /* "restart this scan" function */
regproc amrescan /* "restart this scan" function */ regproc amendscan /* "end this scan" function */
regproc amendscan /* "end this scan" function */ regproc ammarkpos /* "mark current scan position"
regproc ammarkpos /* "mark current scan position" function */
function */ regproc amrestrpos /* "restore marked scan position"
regproc amrestrpos /* "restore marked scan position" function */
function */ regproc amopen /* - deprecated */
regproc amopen /* - deprecated */ regproc amclose /* - deprecated */
regproc amclose /* - deprecated */ regproc ambuild /* "build new index" function */
regproc ambuild /* "build new index" function */ regproc amcreate /* - deprecated */
regproc amcreate /* - deprecated */ regproc amdestroy /* - deprecated */
regproc amdestroy /* - deprecated */ regproc amcostestimate /* estimate cost of an indexscan */
regproc amcostestimate /* estimate cost of an indexscan */
.fi .fi
.nf M .nf M
pg_amop pg_amop
......
<!-- <!--
$Header: /cvsroot/pgsql/doc/src/sgml/xindex.sgml,v 1.7 2000/01/24 07:16:49 tgl Exp $ $Header: /cvsroot/pgsql/doc/src/sgml/xindex.sgml,v 1.8 2000/02/17 03:39:39 tgl Exp $
Postgres documentation Postgres documentation
--> -->
...@@ -51,10 +51,6 @@ Postgres documentation ...@@ -51,10 +51,6 @@ Postgres documentation
<entry>amowner</entry> <entry>amowner</entry>
<entry>object id of the owner's instance in pg_user</entry> <entry>object id of the owner's instance in pg_user</entry>
</row> </row>
<row>
<entry>amkind</entry>
<entry>not used at present, but set to 'o' as a place holder</entry>
</row>
<row> <row>
<entry>amstrategies</entry> <entry>amstrategies</entry>
<entry>number of strategies for this access method (see below)</entry> <entry>number of strategies for this access method (see below)</entry>
...@@ -63,6 +59,11 @@ Postgres documentation ...@@ -63,6 +59,11 @@ Postgres documentation
<entry>amsupport</entry> <entry>amsupport</entry>
<entry>number of support routines for this access method (see below)</entry> <entry>number of support routines for this access method (see below)</entry>
</row> </row>
<row>
<entry>amorderstrategy</entry>
<entry>zero if the index offers no sort order, otherwise the strategy
number of the strategy operator that describes the sort order</entry>
</row>
<row> <row>
<entry>amgettuple</entry> <entry>amgettuple</entry>
</row> </row>
...@@ -217,6 +218,15 @@ SELECT oid FROM pg_am WHERE amname = 'btree'; ...@@ -217,6 +218,15 @@ SELECT oid FROM pg_am WHERE amname = 'btree';
method. The actual routines are listed elsewhere. method. The actual routines are listed elsewhere.
</para> </para>
<para>
By the way, the <filename>amorderstrategy</filename> entry tells whether
the access method supports ordered scan. Zero means it doesn't; if it
does, <filename>amorderstrategy</filename> is the number of the strategy
routine that corresponds to the ordering operator. For example, btree
has <filename>amorderstrategy</filename> = 1 which is its
"less than" strategy number.
</para>
<para> <para>
The next class of interest is pg_opclass. This class exists only to The next class of interest is pg_opclass. This class exists only to
associate a name and default type with an oid. In pg_amop, every associate a name and default type with an oid. In pg_amop, every
......
...@@ -265,6 +265,13 @@ SELECT (a + b) AS c FROM test_complex; ...@@ -265,6 +265,13 @@ SELECT (a + b) AS c FROM test_complex;
yet.) If you do not do this, things will still work, but the optimizer's yet.) If you do not do this, things will still work, but the optimizer's
estimates won't be as good as they could be. estimates won't be as good as they could be.
</para> </para>
<para>
There are additional selectivity functions designed for geometric
operators in src/backend/utils/adt/geo_selfuncs.c: areasel, positionsel,
and contsel. At this writing these are just stubs, but you may want
to use them (or even better, improve them) anyway.
</para>
</sect2> </sect2>
<sect2> <sect2>
...@@ -294,6 +301,9 @@ SELECT (a + b) AS c FROM test_complex; ...@@ -294,6 +301,9 @@ SELECT (a + b) AS c FROM test_complex;
neqjoinsel for &lt;&gt; neqjoinsel for &lt;&gt;
scalarltjoinsel for &lt; or &lt;= scalarltjoinsel for &lt; or &lt;=
scalargtjoinsel for &gt; or &gt;= scalargtjoinsel for &gt; or &gt;=
areajoinsel for 2D area-based comparisons
positionjoinsel for 2D position-based comparisons
contjoinsel for 2D containment-based comparisons
</ProgramListing> </ProgramListing>
</para> </para>
</sect2> </sect2>
......
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/optimizer/util/plancat.c,v 1.47 2000/02/15 20:49:20 tgl Exp $ * $Header: /cvsroot/pgsql/src/backend/optimizer/util/plancat.c,v 1.48 2000/02/17 03:39:40 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -96,8 +96,8 @@ find_secondary_indexes(Query *root, Index relid) ...@@ -96,8 +96,8 @@ find_secondary_indexes(Query *root, Index relid)
IndexOptInfo *info = makeNode(IndexOptInfo); IndexOptInfo *info = makeNode(IndexOptInfo);
int i; int i;
Relation indexRelation; Relation indexRelation;
uint16 amstrategy;
Oid relam; Oid relam;
uint16 amorderstrategy;
/* /*
* Need to make these arrays large enough to be sure there is a * Need to make these arrays large enough to be sure there is a
...@@ -129,37 +129,38 @@ find_secondary_indexes(Query *root, Index relid) ...@@ -129,37 +129,38 @@ find_secondary_indexes(Query *root, Index relid)
/* Extract info from the relation descriptor for the index */ /* Extract info from the relation descriptor for the index */
indexRelation = index_open(index->indexrelid); indexRelation = index_open(index->indexrelid);
#ifdef notdef
/* XXX should iterate through strategies -- but how? use #1 for now */
amstrategy = indexRelation->rd_am->amstrategies;
#endif /* notdef */
amstrategy = 1;
relam = indexRelation->rd_rel->relam; relam = indexRelation->rd_rel->relam;
info->relam = relam; info->relam = relam;
info->pages = indexRelation->rd_rel->relpages; info->pages = indexRelation->rd_rel->relpages;
info->tuples = indexRelation->rd_rel->reltuples; info->tuples = indexRelation->rd_rel->reltuples;
info->amcostestimate = index_cost_estimator(indexRelation); info->amcostestimate = index_cost_estimator(indexRelation);
amorderstrategy = indexRelation->rd_am->amorderstrategy;
index_close(indexRelation); index_close(indexRelation);
/* /*
* Fetch the ordering operators associated with the index. * Fetch the ordering operators associated with the index,
* * if any.
* XXX what if it's a hash or other unordered index?
*/ */
MemSet(info->ordering, 0, sizeof(Oid) * (INDEX_MAX_KEYS+1)); MemSet(info->ordering, 0, sizeof(Oid) * (INDEX_MAX_KEYS+1));
for (i = 0; i < INDEX_MAX_KEYS && index->indclass[i]; i++) if (amorderstrategy != 0)
{ {
HeapTuple amopTuple; for (i = 0; i < INDEX_MAX_KEYS && index->indclass[i]; i++)
{
HeapTuple amopTuple;
Form_pg_amop amop;
amopTuple = SearchSysCacheTuple(AMOPSTRATEGY, amopTuple =
SearchSysCacheTuple(AMOPSTRATEGY,
ObjectIdGetDatum(relam), ObjectIdGetDatum(relam),
ObjectIdGetDatum(index->indclass[i]), ObjectIdGetDatum(index->indclass[i]),
UInt16GetDatum(amstrategy), UInt16GetDatum(amorderstrategy),
0); 0);
if (!HeapTupleIsValid(amopTuple)) if (!HeapTupleIsValid(amopTuple))
elog(ERROR, "find_secondary_indexes: no amop %u %u %d", elog(ERROR, "find_secondary_indexes: no amop %u %u %d",
relam, index->indclass[i], amstrategy); relam, index->indclass[i], (int) amorderstrategy);
info->ordering[i] = ((Form_pg_amop) GETSTRUCT(amopTuple))->amopopr; amop = (Form_pg_amop) GETSTRUCT(amopTuple);
info->ordering[i] = amop->amopopr;
}
} }
indexes = lcons(info, indexes); indexes = lcons(info, indexes);
......
/*------------------------------------------------------------------------- /*-------------------------------------------------------------------------
* *
* geo-selfuncs.c * geo_selfuncs.c
* Selectivity routines registered in the operator catalog in the * Selectivity routines registered in the operator catalog in the
* "oprrest" and "oprjoin" attributes. * "oprrest" and "oprjoin" attributes.
* *
...@@ -9,9 +9,10 @@ ...@@ -9,9 +9,10 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/utils/adt/geo_selfuncs.c,v 1.12 2000/01/26 05:57:14 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/utils/adt/geo_selfuncs.c,v 1.13 2000/02/17 03:39:42 tgl Exp $
* *
* XXX These are totally bogus. * XXX These are totally bogus. Perhaps someone will make them do
* something reasonable, someday.
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -19,17 +20,41 @@ ...@@ -19,17 +20,41 @@
#include "utils/builtins.h" #include "utils/builtins.h"
/*
* Selectivity functions for rtrees. These are bogus -- unless we know
* the actual key distribution in the index, we can't make a good prediction
* of the selectivity of these operators.
*
* Note: the values used here may look unreasonably small. Perhaps they
* are. For now, we want to make sure that the optimizer will make use
* of an r-tree index if one is available, so the selectivity had better
* be fairly small.
*
* In general, rtrees need to search multiple subtrees in order to guarantee
* that all occurrences of the same key have been found. Because of this,
* the estimated cost for scanning the index ought to be higher than the
* output selectivity would indicate. rtcostestimate(), over in selfuncs.c,
* ought to be adjusted accordingly --- but until we can generate somewhat
* realistic numbers here, it hardly matters...
*/
/*
* Selectivity for operators that depend on area, such as "overlap".
*/
float64 float64
areasel(Oid opid, areasel(Oid opid,
Oid relid, Oid relid,
AttrNumber attno, AttrNumber attno,
char *value, Datum value,
int32 flag) int32 flag)
{ {
float64 result; float64 result;
result = (float64) palloc(sizeof(float64data)); result = (float64) palloc(sizeof(float64data));
*result = 1.0 / 4.0; *result = 0.05;
return result; return result;
} }
...@@ -43,81 +68,66 @@ areajoinsel(Oid opid, ...@@ -43,81 +68,66 @@ areajoinsel(Oid opid,
float64 result; float64 result;
result = (float64) palloc(sizeof(float64data)); result = (float64) palloc(sizeof(float64data));
*result = 1.0 / 4.0; *result = 0.05;
return result; return result;
} }
/* /*
* Selectivity functions for rtrees. These are bogus -- unless we know * positionsel
* the actual key distribution in the index, we can't make a good prediction
* of the selectivity of these operators.
* *
* In general, rtrees need to search multiple subtrees in order to guarantee * How likely is a box to be strictly left of (right of, above, below)
* that all occurrences of the same key have been found. Because of this, * a given box?
* the heuristic selectivity functions we return are higher than they would
* otherwise be.
*/
/*
* left_sel -- How likely is a box to be strictly left of (right of, above,
* below) a given box?
*/ */
#ifdef NOT_USED
float64 float64
leftsel(Oid opid, positionsel(Oid opid,
Oid relid, Oid relid,
AttrNumber attno, AttrNumber attno,
char *value, Datum value,
int32 flag) int32 flag)
{ {
float64 result; float64 result;
result = (float64) palloc(sizeof(float64data)); result = (float64) palloc(sizeof(float64data));
*result = 1.0 / 6.0; *result = 0.1;
return result; return result;
} }
#endif
#ifdef NOT_USED
float64 float64
leftjoinsel(Oid opid, positionjoinsel(Oid opid,
Oid relid1, Oid relid1,
AttrNumber attno1, AttrNumber attno1,
Oid relid2, Oid relid2,
AttrNumber attno2) AttrNumber attno2)
{ {
float64 result; float64 result;
result = (float64) palloc(sizeof(float64data)); result = (float64) palloc(sizeof(float64data));
*result = 1.0 / 6.0; *result = 0.1;
return result; return result;
} }
#endif
/* /*
* contsel -- How likely is a box to contain (be contained by) a given box? * contsel -- How likely is a box to contain (be contained by) a given box?
*
* This is a tighter constraint than "overlap", so produce a smaller
* estimate than areasel does.
*/ */
#ifdef NOT_USED
float64 float64
contsel(Oid opid, contsel(Oid opid,
Oid relid, Oid relid,
AttrNumber attno, AttrNumber attno,
char *value, Datum value,
int32 flag) int32 flag)
{ {
float64 result; float64 result;
result = (float64) palloc(sizeof(float64data)); result = (float64) palloc(sizeof(float64data));
*result = 1.0 / 10.0; *result = 0.01;
return result; return result;
} }
#endif
#ifdef NOT_USED
float64 float64
contjoinsel(Oid opid, contjoinsel(Oid opid,
Oid relid1, Oid relid1,
...@@ -128,8 +138,6 @@ contjoinsel(Oid opid, ...@@ -128,8 +138,6 @@ contjoinsel(Oid opid,
float64 result; float64 result;
result = (float64) palloc(sizeof(float64data)); result = (float64) palloc(sizeof(float64data));
*result = 1.0 / 10.0; *result = 0.01;
return result; return result;
} }
#endif
...@@ -37,7 +37,7 @@ ...@@ -37,7 +37,7 @@
* Portions Copyright (c) 1996-2000, PostgreSQL, Inc * Portions Copyright (c) 1996-2000, PostgreSQL, Inc
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $Id: catversion.h,v 1.15 2000/02/16 17:26:06 thomas Exp $ * $Id: catversion.h,v 1.16 2000/02/17 03:39:45 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -53,6 +53,6 @@ ...@@ -53,6 +53,6 @@
*/ */
/* yyyymmddN */ /* yyyymmddN */
#define CATALOG_VERSION_NO 200002161 #define CATALOG_VERSION_NO 200002162
#endif #endif
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* Portions Copyright (c) 1996-2000, PostgreSQL, Inc * Portions Copyright (c) 1996-2000, PostgreSQL, Inc
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $Id: pg_am.h,v 1.13 2000/01/26 05:57:56 momjian Exp $ * $Id: pg_am.h,v 1.14 2000/02/17 03:39:47 tgl Exp $
* *
* NOTES * NOTES
* the genbki.sh script reads this file and generates .bki * the genbki.sh script reads this file and generates .bki
...@@ -36,29 +36,33 @@ ...@@ -36,29 +36,33 @@
*/ */
CATALOG(pg_am) CATALOG(pg_am)
{ {
NameData amname; NameData amname; /* access method name */
int4 amowner; int4 amowner; /* usesysid of creator */
char amkind; int2 amstrategies; /* total NUMBER of strategies by which
int2 amstrategies; * we can traverse/search this AM */
int2 amsupport; int2 amsupport; /* total NUMBER of support functions
regproc amgettuple; * that this AM uses */
regproc aminsert; int2 amorderstrategy; /* if this AM has a sort order, the
regproc amdelete; * strategy number of the sort operator.
regproc amgetattr; * Zero if AM is not ordered. */
regproc amsetlock; regproc amgettuple; /* "next valid tuple" function */
regproc amsettid; regproc aminsert; /* "insert this tuple" function */
regproc amfreetuple; regproc amdelete; /* "delete this tuple" function */
regproc ambeginscan; regproc amgetattr; /* - deprecated */
regproc amrescan; regproc amsetlock; /* - deprecated */
regproc amendscan; regproc amsettid; /* - deprecated */
regproc ammarkpos; regproc amfreetuple; /* - deprecated */
regproc amrestrpos; regproc ambeginscan; /* "start new scan" function */
regproc amopen; regproc amrescan; /* "restart this scan" function */
regproc amclose; regproc amendscan; /* "end this scan" function */
regproc ambuild; regproc ammarkpos; /* "mark current scan position" function */
regproc amcreate; regproc amrestrpos; /* "restore marked scan position" function */
regproc amdestroy; regproc amopen; /* - deprecated */
regproc amcostestimate; regproc amclose; /* - deprecated */
regproc ambuild; /* "build new index" function */
regproc amcreate; /* - deprecated */
regproc amdestroy; /* - deprecated */
regproc amcostestimate; /* estimate cost of an indexscan */
} FormData_pg_am; } FormData_pg_am;
/* ---------------- /* ----------------
...@@ -75,9 +79,9 @@ typedef FormData_pg_am *Form_pg_am; ...@@ -75,9 +79,9 @@ typedef FormData_pg_am *Form_pg_am;
#define Natts_pg_am 23 #define Natts_pg_am 23
#define Anum_pg_am_amname 1 #define Anum_pg_am_amname 1
#define Anum_pg_am_amowner 2 #define Anum_pg_am_amowner 2
#define Anum_pg_am_amkind 3 #define Anum_pg_am_amstrategies 3
#define Anum_pg_am_amstrategies 4 #define Anum_pg_am_amsupport 4
#define Anum_pg_am_amsupport 5 #define Anum_pg_am_amorderstrategy 5
#define Anum_pg_am_amgettuple 6 #define Anum_pg_am_amgettuple 6
#define Anum_pg_am_aminsert 7 #define Anum_pg_am_aminsert 7
#define Anum_pg_am_amdelete 8 #define Anum_pg_am_amdelete 8
...@@ -102,15 +106,15 @@ typedef FormData_pg_am *Form_pg_am; ...@@ -102,15 +106,15 @@ typedef FormData_pg_am *Form_pg_am;
* ---------------- * ----------------
*/ */
DATA(insert OID = 402 ( rtree PGUID "o" 8 3 rtgettuple rtinsert rtdelete - - - - rtbeginscan rtrescan rtendscan rtmarkpos rtrestrpos - - rtbuild - - rtcostestimate )); DATA(insert OID = 402 ( rtree PGUID 8 3 0 rtgettuple rtinsert rtdelete - - - - rtbeginscan rtrescan rtendscan rtmarkpos rtrestrpos - - rtbuild - - rtcostestimate ));
DESCR(""); DESCR("");
DATA(insert OID = 403 ( btree PGUID "o" 5 1 btgettuple btinsert btdelete - - - - btbeginscan btrescan btendscan btmarkpos btrestrpos - - btbuild - - btcostestimate )); DATA(insert OID = 403 ( btree PGUID 5 1 1 btgettuple btinsert btdelete - - - - btbeginscan btrescan btendscan btmarkpos btrestrpos - - btbuild - - btcostestimate ));
DESCR(""); DESCR("");
#define BTREE_AM_OID 403 #define BTREE_AM_OID 403
DATA(insert OID = 405 ( hash PGUID "o" 1 1 hashgettuple hashinsert hashdelete - - - - hashbeginscan hashrescan hashendscan hashmarkpos hashrestrpos - - hashbuild - - hashcostestimate )); DATA(insert OID = 405 ( hash PGUID 1 1 0 hashgettuple hashinsert hashdelete - - - - hashbeginscan hashrescan hashendscan hashmarkpos hashrestrpos - - hashbuild - - hashcostestimate ));
DESCR(""); DESCR("");
#define HASH_AM_OID 405 #define HASH_AM_OID 405
DATA(insert OID = 783 ( gist PGUID "o" 100 7 gistgettuple gistinsert gistdelete - - - - gistbeginscan gistrescan gistendscan gistmarkpos gistrestrpos - - gistbuild - - gistcostestimate )); DATA(insert OID = 783 ( gist PGUID 100 7 0 gistgettuple gistinsert gistdelete - - - - gistbeginscan gistrescan gistendscan gistmarkpos gistrestrpos - - gistbuild - - gistcostestimate ));
DESCR(""); DESCR("");
#endif /* PG_AM_H */ #endif /* PG_AM_H */
This diff is collapsed.
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* Portions Copyright (c) 1996-2000, PostgreSQL, Inc * Portions Copyright (c) 1996-2000, PostgreSQL, Inc
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $Id: pg_proc.h,v 1.122 2000/02/16 17:26:07 thomas Exp $ * $Id: pg_proc.h,v 1.123 2000/02/17 03:39:48 tgl Exp $
* *
* NOTES * NOTES
* The script catalog/genbki.sh reads this file and generates .bki * The script catalog/genbki.sh reads this file and generates .bki
...@@ -293,9 +293,9 @@ DESCR("contained in"); ...@@ -293,9 +293,9 @@ DESCR("contained in");
DATA(insert OID = 138 ( box_center PGUID 11 f t t 1 f 600 "603" 100 1 0 100 box_center - )); DATA(insert OID = 138 ( box_center PGUID 11 f t t 1 f 600 "603" 100 1 0 100 box_center - ));
DESCR("center of"); DESCR("center of");
DATA(insert OID = 139 ( areasel PGUID 11 f t f 5 f 701 "26 26 21 0 23" 100 0 0 100 areasel - )); DATA(insert OID = 139 ( areasel PGUID 11 f t f 5 f 701 "26 26 21 0 23" 100 0 0 100 areasel - ));
DESCR("restriction selectivity for operators on areas"); DESCR("restriction selectivity for area-comparison operators");
DATA(insert OID = 140 ( areajoinsel PGUID 11 f t f 5 f 701 "26 26 21 26 21" 100 0 0 100 areajoinsel - )); DATA(insert OID = 140 ( areajoinsel PGUID 11 f t f 5 f 701 "26 26 21 26 21" 100 0 0 100 areajoinsel - ));
DESCR("join selectivity for operators on areas"); DESCR("join selectivity for area-comparison operators");
DATA(insert OID = 141 ( int4mul PGUID 11 f t t 2 f 23 "23 23" 100 0 0 100 int4mul - )); DATA(insert OID = 141 ( int4mul PGUID 11 f t t 2 f 23 "23 23" 100 0 0 100 int4mul - ));
DESCR("multiply"); DESCR("multiply");
DATA(insert OID = 142 ( int4fac PGUID 11 f t t 1 f 23 "23" 100 0 0 100 int4fac - )); DATA(insert OID = 142 ( int4fac PGUID 11 f t t 1 f 23 "23" 100 0 0 100 int4fac - ));
...@@ -1565,6 +1565,15 @@ DESCR("current transaction time"); ...@@ -1565,6 +1565,15 @@ DESCR("current transaction time");
/* OIDS 1300 - 1399 */ /* OIDS 1300 - 1399 */
DATA(insert OID = 1300 ( positionsel PGUID 11 f t f 5 f 701 "26 26 21 0 23" 100 0 0 100 positionsel - ));
DESCR("restriction selectivity for position-comparison operators");
DATA(insert OID = 1301 ( positionjoinsel PGUID 11 f t f 5 f 701 "26 26 21 26 21" 100 0 0 100 positionjoinsel - ));
DESCR("join selectivity for position-comparison operators");
DATA(insert OID = 1302 ( contsel PGUID 11 f t f 5 f 701 "26 26 21 0 23" 100 0 0 100 contsel - ));
DESCR("restriction selectivity for containment comparison operators");
DATA(insert OID = 1303 ( contjoinsel PGUID 11 f t f 5 f 701 "26 26 21 26 21" 100 0 0 100 contjoinsel - ));
DESCR("join selectivity for containment comparison operators");
DATA(insert OID = 1314 ( timestamp_cmp PGUID 11 f t f 2 f 23 "1184 1184" 100 0 0 100 timestamp_cmp - )); DATA(insert OID = 1314 ( timestamp_cmp PGUID 11 f t f 2 f 23 "1184 1184" 100 0 0 100 timestamp_cmp - ));
DESCR("less-equal-greater"); DESCR("less-equal-greater");
DATA(insert OID = 1315 ( interval_cmp PGUID 11 f t f 2 f 23 "1186 1186" 100 0 0 100 interval_cmp - )); DATA(insert OID = 1315 ( interval_cmp PGUID 11 f t f 2 f 23 "1186 1186" 100 0 0 100 interval_cmp - ));
......
...@@ -6,12 +6,13 @@ ...@@ -6,12 +6,13 @@
* Portions Copyright (c) 1996-2000, PostgreSQL, Inc * Portions Copyright (c) 1996-2000, PostgreSQL, Inc
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $Id: geo_decls.h,v 1.24 2000/01/26 05:58:38 momjian Exp $ * $Id: geo_decls.h,v 1.25 2000/02/17 03:39:51 tgl Exp $
* *
* NOTE * NOTE
* These routines do *not* use the float types from adt/. * These routines do *not* use the float types from adt/.
* *
* XXX These routines were not written by a numerical analyst. * XXX These routines were not written by a numerical analyst.
*
* XXX I have made some attempt to flesh out the operators * XXX I have made some attempt to flesh out the operators
* and data types. There are still some more to do. - tgl 97/04/19 * and data types. There are still some more to do. - tgl 97/04/19
* *
...@@ -362,8 +363,16 @@ extern double circle_dt(CIRCLE *circle1, CIRCLE *circle2); ...@@ -362,8 +363,16 @@ extern double circle_dt(CIRCLE *circle1, CIRCLE *circle2);
/* geo_selfuncs.c */ /* geo_selfuncs.c */
extern float64 areasel(Oid opid, Oid relid, AttrNumber attno, extern float64 areasel(Oid opid, Oid relid, AttrNumber attno,
char *value, int32 flag); Datum value, int32 flag);
extern float64 areajoinsel(Oid opid, Oid relid1, AttrNumber attno1, extern float64 areajoinsel(Oid opid, Oid relid1, AttrNumber attno1,
Oid relid2, AttrNumber attno2); Oid relid2, AttrNumber attno2);
extern float64 positionsel(Oid opid, Oid relid, AttrNumber attno,
Datum value, int32 flag);
extern float64 positionjoinsel(Oid opid, Oid relid1, AttrNumber attno1,
Oid relid2, AttrNumber attno2);
extern float64 contsel(Oid opid, Oid relid, AttrNumber attno,
Datum value, int32 flag);
extern float64 contjoinsel(Oid opid, Oid relid1, AttrNumber attno1,
Oid relid2, AttrNumber attno2);
#endif /* GEO_DECLS_H */ #endif /* GEO_DECLS_H */
...@@ -47,10 +47,22 @@ CREATE INDEX bt_f8_index ON bt_f8_heap USING btree (seqno float8_ops); ...@@ -47,10 +47,22 @@ CREATE INDEX bt_f8_index ON bt_f8_heap USING btree (seqno float8_ops);
-- --
-- rtrees use a quadratic page-splitting algorithm that takes a -- rtrees use a quadratic page-splitting algorithm that takes a
-- really, really long time. we don't test all rtree opclasses -- really, really long time. we don't test all rtree opclasses
-- in the regression test (we check them USING the sequoia 2000 -- in the regression test (we check them using the sequoia 2000
-- benchmark). -- benchmark).
-- --
CREATE INDEX rect2ind ON fast_emp4000 USING rtree (home_base bigbox_ops); CREATE INDEX rect2ind ON fast_emp4000 USING rtree (home_base bigbox_ops);
-- there's no easy way to check that this command actually is using
-- the index, unfortunately. (EXPLAIN would work, but its output
-- changes too often for me to want to put an EXPLAIN in the test...)
SELECT * FROM fast_emp4000
WHERE home_base @ '(200,200),(2000,1000)'::box
ORDER BY home_base USING <<;
home_base
-----------------------
(337,455),(240,359)
(1444,403),(1346,344)
(2 rows)
-- --
-- HASH -- HASH
-- --
......
...@@ -70,11 +70,17 @@ CREATE INDEX bt_f8_index ON bt_f8_heap USING btree (seqno float8_ops); ...@@ -70,11 +70,17 @@ CREATE INDEX bt_f8_index ON bt_f8_heap USING btree (seqno float8_ops);
-- --
-- rtrees use a quadratic page-splitting algorithm that takes a -- rtrees use a quadratic page-splitting algorithm that takes a
-- really, really long time. we don't test all rtree opclasses -- really, really long time. we don't test all rtree opclasses
-- in the regression test (we check them USING the sequoia 2000 -- in the regression test (we check them using the sequoia 2000
-- benchmark). -- benchmark).
-- --
CREATE INDEX rect2ind ON fast_emp4000 USING rtree (home_base bigbox_ops); CREATE INDEX rect2ind ON fast_emp4000 USING rtree (home_base bigbox_ops);
-- there's no easy way to check that this command actually is using
-- the index, unfortunately. (EXPLAIN would work, but its output
-- changes too often for me to want to put an EXPLAIN in the test...)
SELECT * FROM fast_emp4000
WHERE home_base @ '(200,200),(2000,1000)'::box
ORDER BY home_base USING <<;
-- --
-- HASH -- HASH
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment