1. 09 Jan, 2007 1 commit
    • Tom Lane's avatar
      Support ORDER BY ... NULLS FIRST/LAST, and add ASC/DESC/NULLS FIRST/NULLS LAST · 44317582
      Tom Lane authored
      per-column options for btree indexes.  The planner's support for this is still
      pretty rudimentary; it does not yet know how to plan mergejoins with
      nondefault ordering options.  The documentation is pretty rudimentary, too.
      I'll work on improving that stuff later.
      
      Note incompatible change from prior behavior: ORDER BY ... USING will now be
      rejected if the operator is not a less-than or greater-than member of some
      btree opclass.  This prevents less-than-sane behavior if an operator that
      doesn't actually define a proper sort ordering is selected.
      44317582
  2. 08 Jan, 2007 3 commits
    • Peter Eisentraut's avatar
      3a32ba2f
    • Tom Lane's avatar
      Tweak joinlist creation to avoid generating useless one-element subproblems · 19f9376b
      Tom Lane authored
      when collapsing of JOIN trees is stopped by join_collapse_limit.  For instance
      a list of 11 LEFT JOINs with limit 8 now produces something like
      	((1 2 3 4 5 6 7 8) 9 10 11 12)
      instead of
      	(((1 2 3 4 5 6 7 8) (9)) 10 11 12)
      The latter structure is really only required for a FULL JOIN.
      Noted while studying an example from Shane Ambler.
      19f9376b
    • Tom Lane's avatar
      Remove cost_hashjoin's very ancient hack to discourage (once, entirely forbid) · 9a9a143a
      Tom Lane authored
      hash joins with the estimated-larger relation on the inside.  There are
      several cases where doing that makes perfect sense, and in cases where it
      doesn't, the regular cost computation really ought to be able to figure that
      out.  Make some marginal tweaks in said computation to try to get results
      approximating reality a bit better.  Per an example from Shane Ambler.
      
      Also, fix an oversight in the original patch to add seq_page_cost: the costs
      of spilling a hash join to disk should be scaled by seq_page_cost.
      9a9a143a
  3. 07 Jan, 2007 4 commits
  4. 06 Jan, 2007 17 commits
  5. 05 Jan, 2007 12 commits
  6. 04 Jan, 2007 3 commits