Commit c99ddfc4 authored by Tom Lane's avatar Tom Lane

Enable btree_predicate_proof() to make proofs involving cross-data-type

predicate operators.  The hard stuff turns out to be already done in the
previous commit, we need merely open the floodgates...
parent 91868e7d
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/optimizer/util/predtest.c,v 1.11 2006/12/23 00:43:11 tgl Exp $ * $PostgreSQL: pgsql/src/backend/optimizer/util/predtest.c,v 1.12 2006/12/28 19:53:05 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -1131,7 +1131,7 @@ static const StrategyNumber BT_refute_table[6][6] = { ...@@ -1131,7 +1131,7 @@ static const StrategyNumber BT_refute_table[6][6] = {
}; };
/*---------- /*
* btree_predicate_proof * btree_predicate_proof
* Does the predicate implication or refutation test for a "simple clause" * Does the predicate implication or refutation test for a "simple clause"
* predicate and a "simple clause" restriction, when both are simple * predicate and a "simple clause" restriction, when both are simple
...@@ -1152,7 +1152,6 @@ static const StrategyNumber BT_refute_table[6][6] = { ...@@ -1152,7 +1152,6 @@ static const StrategyNumber BT_refute_table[6][6] = {
* the operators are too. As of 8.0 it's possible for opfamilies to contain * the operators are too. As of 8.0 it's possible for opfamilies to contain
* operators that are merely stable, and we dare not make deductions with * operators that are merely stable, and we dare not make deductions with
* these.) * these.)
*----------
*/ */
static bool static bool
btree_predicate_proof(Expr *predicate, Node *clause, bool refute_it) btree_predicate_proof(Expr *predicate, Node *clause, bool refute_it)
...@@ -1274,15 +1273,9 @@ btree_predicate_proof(Expr *predicate, Node *clause, bool refute_it) ...@@ -1274,15 +1273,9 @@ btree_predicate_proof(Expr *predicate, Node *clause, bool refute_it)
/* /*
* Try to find a btree opfamily containing the needed operators. * Try to find a btree opfamily containing the needed operators.
* *
* XXX this needs work!!!!!!!!!!!!!!!!!!!!!!!
*
* We must find a btree opfamily that contains both operators, else the * We must find a btree opfamily that contains both operators, else the
* implication can't be determined. Also, the pred_op has to be of * implication can't be determined. Also, the opfamily must contain a
* default subtype (implying left and right input datatypes are the same); * suitable test operator taking the pred_const and clause_const datatypes.
* otherwise it's unsafe to put the pred_const on the left side of the
* test. Also, the opfamily must contain a suitable test operator matching
* the clause_const's type (which we take to mean that it has the same
* subtype as the original clause_operator).
* *
* If there are multiple matching opfamilies, assume we can use any one to * If there are multiple matching opfamilies, assume we can use any one to
* determine the logical relationship of the two operators and the correct * determine the logical relationship of the two operators and the correct
...@@ -1321,12 +1314,9 @@ btree_predicate_proof(Expr *predicate, Node *clause, bool refute_it) ...@@ -1321,12 +1314,9 @@ btree_predicate_proof(Expr *predicate, Node *clause, bool refute_it)
Form_pg_amop pred_form = (Form_pg_amop) GETSTRUCT(pred_tuple); Form_pg_amop pred_form = (Form_pg_amop) GETSTRUCT(pred_tuple);
HeapTuple clause_tuple; HeapTuple clause_tuple;
/* must be btree */ /* Must be btree */
if (pred_form->amopmethod != BTREE_AM_OID) if (pred_form->amopmethod != BTREE_AM_OID)
continue; continue;
/* predicate operator must be default within this opfamily */
if (pred_form->amoplefttype != pred_form->amoprighttype)
continue;
/* Get the predicate operator's btree strategy number */ /* Get the predicate operator's btree strategy number */
opfamily_id = pred_form->amopfamily; opfamily_id = pred_form->amopfamily;
......
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