Re: indxpath.c refactoring - Mailing list pgsql-patches

From Tom Lane
Subject Re: indxpath.c refactoring
Date
Msg-id 6154.1118442809@sss.pgh.pa.us
Whole thread Raw
In response to indxpath.c refactoring  (Simon Riggs <simon@2ndquadrant.com>)
Responses Re: indxpath.c refactoring
Re: indxpath.c refactoring
List pgsql-patches
Simon Riggs <simon@2ndquadrant.com> writes:
> This simple refactoring patch moves all of the code associated with
> Partial Index planning into a single file.

Applied with some revisions -

* I put the new predtest.c file into optimizer/util, which seemed a more
  plausible location than /path, and gave it its own header file.

* I thought check_partial_indexes() should stay in indxpath.c; it is an
  application of the theorem-proving module to indexes, not part of the
  prover proper.

* I took the opportunity to rename pred_test() to predicate_implied_by(),
  which seems more clear about what it's doing and in which direction.


As for the future...

> - redesigning the low level routines to allow them to perform their
> stuff for both Partial Index and Constraint-based elimination (aka
> Partitioning...)

The other main entry point should probably be called something like
predicate_refuted_by?

> - allow handling for r-tree operators

I don't see anyone very excited about r-tree these days; have you
noticed that no one has stepped up to repair the known semantic errors?
I wouldn't spend any time on it in the prover.

> - maybe GIST also??

The trouble with GiST is that the logical structure of each opclass
could be completely different from the next --- it's certainly not
possible to have a simple fixed table of implications.  Again, we have
much more important fish to fry, anyway ...

            regards, tom lane

pgsql-patches by date:

Previous
From: Stephen Frost
Date:
Subject: Re: Grammer Cleanup
Next
From: Neil Conway
Date:
Subject: Re: PQmakeEmptyPGresult() will return NULL if allocation