1. 02 Aug, 1999 3 commits
    • Tom Lane's avatar
      Further selectivity-estimation work. Speed up eqsel() · 8624ff76
      Tom Lane authored
      (it should just call the given operator, not look up an = operator).
      Fix intltsel() so that all numeric data types are converted to double
      before trying to estimate where the given comparison value is in the
      known range of column values.  intltsel() still needs work, or replacement,
      for non-numeric data types ... but for nonintegral numeric types it
      should now be delivering reasonable estimates.
      8624ff76
    • Marc G. Fournier's avatar
      · d35eebe7
      Marc G. Fournier authored
      back out last...
      d35eebe7
    • Marc G. Fournier's avatar
      testing somethign... · 557ff530
      Marc G. Fournier authored
      
      
      557ff530
  2. 01 Aug, 1999 5 commits
  3. 31 Jul, 1999 3 commits
  4. 30 Jul, 1999 11 commits
  5. 29 Jul, 1999 3 commits
  6. 28 Jul, 1999 4 commits
  7. 27 Jul, 1999 3 commits
    • Tom Lane's avatar
      Correct bug in best_innerjoin(): it should check all the · b62fdc13
      Tom Lane authored
      rels that the inner path needs to join to, but it was only checking for
      the first one.  Failure could only have been observed with an OR-clause
      that mentions 3 or more tables, and then only if the bogus path was
      actually selected as cheapest ...
      b62fdc13
    • Tom Lane's avatar
      My recent optimizer changes caused a different plan to · 2f30d5a3
      Tom Lane authored
      be picked for one of the complex joins in rules test ... leading to
      a different output ordering ...
      2f30d5a3
    • Tom Lane's avatar
      First cut at doing LIKE/regex indexing optimization in · 9e7e29e6
      Tom Lane authored
      optimizer rather than parser.  This has many advantages, such as not
      getting fooled by chance uses of operator names ~ and ~~ (the operators
      are identified by OID now), and not creating useless comparison operations
      in contexts where the comparisons will not actually be used as indexquals.
      The new code also recognizes exact-match LIKE and regex patterns, and
      produces an = indexqual instead of >= and <=.
      
      This change does NOT fix the problem with non-ASCII locales: the code
      still doesn't know how to generate an upper bound indexqual for non-ASCII
      collation order.  But it's no worse than before, just the same deficiency
      in a different place...
      
      Also, dike out loc_restrictinfo fields in Plan nodes.  These were doing
      nothing useful in the absence of 'expensive functions' optimization,
      and they took a considerable amount of processing to fill in.
      9e7e29e6
  8. 26 Jul, 1999 2 commits
  9. 25 Jul, 1999 2 commits
  10. 24 Jul, 1999 1 commit
    • Tom Lane's avatar
      Clean up messy clause-selectivity code in clausesel.c; repair bug · ac4913a0
      Tom Lane authored
      identified by Hiroshi (incorrect cost attributed to OR clauses
      after multiple passes through set_rest_selec()).  I think the code
      was trying to allow selectivities of OR subclauses to be passed in
      from outside, but noplace was actually passing any useful data, and
      set_rest_selec() was passing wrong data.
      
      Restructure representation of "indexqual" in IndexPath nodes so that
      it is the same as for indxqual in completed IndexScan nodes: namely,
      a toplevel list with an entry for each pass of the index scan, having
      sublists that are implicitly-ANDed index qual conditions for that pass.
      You don't want to know what the old representation was :-(
      
      Improve documentation of OR-clause indexscan functions.
      
      Remove useless 'notclause' field from RestrictInfo nodes.  (This might
      force an initdb for anyone who has stored rules containing RestrictInfos,
      but I do not think that RestrictInfo ever appears in completed plans.)
      ac4913a0
  11. 23 Jul, 1999 2 commits
  12. 22 Jul, 1999 1 commit