1. 23 Mar, 2011 4 commits
  2. 22 Mar, 2011 7 commits
    • Simon Riggs's avatar
      Make FKs valid at creation when added as column constraints. · ec497a5a
      Simon Riggs authored
      Bug report from Alvaro Herrera
      ec497a5a
    • Tom Lane's avatar
      Make initdb ignore locales for client-only encodings. · 5d1d679d
      Tom Lane authored
      While putting such entries into pg_collation is harmless (since backends
      will ignore entries that don't match the database encoding), it's also
      useless.
      5d1d679d
    • Tom Lane's avatar
      Improve reporting of run-time-detected indeterminate-collation errors. · 6e197cb2
      Tom Lane authored
      pg_newlocale_from_collation does not have enough context to give an error
      message that's even a little bit useful, so move the responsibility for
      complaining up to its callers.  Also, reword ERRCODE_INDETERMINATE_COLLATION
      error messages in a less jargony, more message-style-guide-compliant
      fashion.
      6e197cb2
    • Tom Lane's avatar
      Throw error for indeterminate collation of an ORDER/GROUP/DISTINCT target. · 37d6d07d
      Tom Lane authored
      This restores a parse error that was thrown (though only in the ORDER BY
      case) by the original collation patch.  I had removed it in my recent
      revisions because it was thrown at a place where collations now haven't
      been computed yet; but I thought of another way to handle it.
      
      Throwing the error at parse time, rather than leaving it to be done at
      runtime, is good because a syntax error pointer is helpful for localizing
      the problem.  We can reasonably assume that the comparison function for a
      collatable datatype will complain if it doesn't have a collation to use.
      Now the planner might choose to implement GROUP or DISTINCT via hashing,
      in which case no runtime error would actually occur, but it seems better
      to throw error consistently rather than let the error depend on what the
      planner chooses to do.  Another possible objection is that the user might
      specify a nondefault sort operator that doesn't care about collation
      ... but that's surely an uncommon usage, and it wouldn't hurt him to throw
      in a COLLATE clause anyway.  This change also makes the ORDER BY/GROUP
      BY/DISTINCT case more consistent with the UNION/INTERSECT/EXCEPT case,
      which was already coded to throw this error even though the same objections
      could be raised there.
      37d6d07d
    • Tom Lane's avatar
      Avoid potential deadlock in InitCatCachePhase2(). · 1192ba8b
      Tom Lane authored
      Opening a catcache's index could require reading from that cache's own
      catalog, which of course would acquire AccessShareLock on the catalog.
      So the original coding here risks locking index before heap, which could
      deadlock against another backend trying to get exclusive locks in the
      normal order.  Because InitCatCachePhase2 is only called when a backend
      has to start up without a relcache init file, the deadlock was seldom seen
      in the field.  (And by the same token, there's no need to worry about any
      performance disadvantage; so not much point in trying to distinguish
      exactly which catalogs have the risk.)
      
      Bug report, diagnosis, and patch by Nikhil Sontakke.  Additional commentary
      by me.  Back-patch to all supported branches.
      1192ba8b
    • Simon Riggs's avatar
    • Tom Lane's avatar
      Reimplement planner's handling of MIN/MAX aggregate optimization (again). · 8df08c84
      Tom Lane authored
      Instead of playing cute games with pathkeys, just build a direct
      representation of the intended sub-select, and feed it through
      query_planner to get a Path for the index access.  This is a bit slower
      than 9.1's previous method, since we'll duplicate most of the overhead of
      query_planner; but since the whole optimization only applies to rather
      simple single-table queries, that probably won't be much of a problem in
      practice.  The advantage is that we get to do the right thing when there's
      a partial index that needs the implicit IS NOT NULL clause to be usable.
      Also, although this makes planagg.c be a bit more closely tied to the
      ordering of operations in grouping_planner, we can get rid of some coupling
      to lower-level parts of the planner.  Per complaint from Marti Raudsepp.
      8df08c84
  3. 21 Mar, 2011 2 commits
  4. 20 Mar, 2011 11 commits
  5. 19 Mar, 2011 8 commits
  6. 18 Mar, 2011 5 commits
  7. 17 Mar, 2011 3 commits