1. 30 Jul, 2009 1 commit
    • Tom Lane's avatar
      Merge the Constraint and FkConstraint node types into a single type. · 060baf27
      Tom Lane authored
      This was foreseen to be a good idea long ago, but nobody had got round
      to doing it.  The recent patch for deferred unique constraints made
      transformConstraintAttrs() ugly enough that I decided it was time.
      This change will also greatly simplify parsing of deferred CHECK constraints,
      if anyone ever gets around to implementing that.
      
      While at it, add a location field to Constraint, and use that to provide
      an error cursor for some of the constraint-related error messages.
      060baf27
  2. 29 Jul, 2009 3 commits
    • Tom Lane's avatar
      Fix time_part and timetz_part (ie, EXTRACT() for those datatypes) to · 78aef14c
      Tom Lane authored
      include a fractional part in the output for MILLISECOND and SECOND cases,
      rather than truncating the source value.  This is what the float-timestamp
      code has always done, and it was clearly the code author's intent to do
      the same for integer timestamps, but he forgot about integer division in C.
      The other datatypes supported by EXTRACT() already do this correctly.
      
      Backpatch to 8.4, so that the default (integer) behavior of that branch will
      match the default (float) behavior of older branches.  Arguably we should
      patch further back, but it's possible that applications are expecting the
      broken behavior in older branches.  8.4 is new enough that expectations
      shouldn't be too settled.
      
      Per report from Greg Stark.
      78aef14c
    • Tom Lane's avatar
      Support deferrable uniqueness constraints. · 25d9bf2e
      Tom Lane authored
      The current implementation fires an AFTER ROW trigger for each tuple that
      looks like it might be non-unique according to the index contents at the
      time of insertion.  This works well as long as there aren't many conflicts,
      but won't scale to massive unique-key reassignments.  Improving that case
      is a TODO item.
      
      Dean Rasheed
      25d9bf2e
    • Tom Lane's avatar
      Fix a thinko introduced into CountActiveBackends by a recent patch: · 85049057
      Tom Lane authored
      we should ignore NULL array entries, not non-NULL ones.  This had the
      effect of disabling commit_delay, and could have caused a crash in the
      rare race condition the patch was intended to fix.
      
      Bug report and diagnosis by Jeff Janes, in bug #4952.
      85049057
  3. 28 Jul, 2009 3 commits
  4. 27 Jul, 2009 6 commits
  5. 26 Jul, 2009 1 commit
    • Tom Lane's avatar
      Extend EXPLAIN to allow generic options to be specified. · d4382c4a
      Tom Lane authored
      The original syntax made it difficult to add options without making them
      into reserved words.  This change parenthesizes the options to avoid that
      problem, and makes provision for an explicit (and perhaps non-Boolean)
      value for each option.  The original syntax is still supported, but only
      for the two original options ANALYZE and VERBOSE.
      
      As a test case, add a COSTS option that can suppress the planner cost
      estimates.  This may be useful for including EXPLAIN output in the regression
      tests, which are otherwise unable to cope with cross-platform variations in
      cost estimates.
      
      Robert Haas
      d4382c4a
  6. 25 Jul, 2009 3 commits
  7. 24 Jul, 2009 5 commits
    • Tom Lane's avatar
      Assorted minor refactoring in EXPLAIN. · 8af12bca
      Tom Lane authored
      This is believed to not change the output at all, with one known exception:
      "Subquery Scan foo" becomes "Subquery Scan on foo".  (We can fix that if
      anyone complains, but it would be a wart, because the old code was clearly
      inconsistent.)  The main intention is to remove duplicate coding and
      provide a cleaner base for subsequent EXPLAIN patching.
      
      Robert Haas
      8af12bca
    • Magnus Hagander's avatar
      Reserve the shared memory region during backend startup on Windows, so · a7e58786
      Magnus Hagander authored
      that memory allocated by starting third party DLLs doesn't end up
      conflicting with it.
      
      Hopefully this solves the long-time issue with "could not reattach
      to shared memory" errors on Win32.
      
      Patch from Tsutomu Yamada and me, based on idea from Trevor Talbot.
      a7e58786
    • Peter Eisentraut's avatar
      Document \dg+ and \du+ · 5e229941
      Peter Eisentraut authored
      The fact that \dg and \du take the + option was missing in the documentation.
      
      backpatched to 8.4
      
      Author: Andreas Wenk <a.wenk@netzmeister-st-pauli.de>
      5e229941
    • Tom Lane's avatar
      Avoid extra system calls to block SIGPIPE if the platform provides either · cea80e72
      Tom Lane authored
      sockopt(SO_NOSIGPIPE) or the MSG_NOSIGNAL flag to send().
      
      We assume these features are available if (1) the symbol is defined at
      compile time and (2) the kernel doesn't reject the call at runtime.
      It might turn out that there are some platforms where (1) and (2) are
      true and yet the signal isn't really blocked, in which case applications
      would die on server crash.  If that sort of thing gets reported, then
      we'll have to add additional defenses of some kind.
      
      Jeremy Kerr
      cea80e72
    • Tom Lane's avatar
  8. 23 Jul, 2009 6 commits
    • Andrew Dunstan's avatar
      Force use of our erand48 on Cygwin · dc7aa365
      Andrew Dunstan authored
      dc7aa365
    • Tom Lane's avatar
      Teach pg_dump to dump comments attached to the columns of a composite type. · 0d6909ea
      Tom Lane authored
      Taro Minowa (Higepon)
      0d6909ea
    • Tom Lane's avatar
      Save a few cycles in EXPLAIN and related commands by not bothering to form · adfa0429
      Tom Lane authored
      a physical tuple in do_tup_output().  A virtual tuple is easier to set up
      and also easier for most tuple receivers to process.  Per my comment on
      Robert Haas' recent patch in this code.
      adfa0429
    • Tom Lane's avatar
      In a non-hashed Agg node, reset the "aggcontext" at group boundaries, instead · 6a0865e4
      Tom Lane authored
      of individually pfree'ing pass-by-reference transition values.  This should
      be at least as fast as the prior coding, and it has the major advantage of
      clearing out any working data an aggregate function may have stored in or
      underneath the aggcontext.  This avoids memory leakage when an aggregate
      such as array_agg() is used in GROUP BY mode.  Per report from Chris Spotts.
      
      Back-patch to 8.4.  In principle the problem could arise in prior versions,
      but since they didn't have array_agg the issue seems not critical.
      6a0865e4
    • Tom Lane's avatar
      Fix another thinko in join_is_legal's handling of semijoins: we have to test · 1ca695db
      Tom Lane authored
      for the case that the semijoin was implemented within either input by
      unique-ifying its RHS before we test to see if it appears to match the current
      join situation.  The previous coding would select semijoin logic in situations
      where we'd already unique-ified the RHS and joined it to some unrelated
      relation(s), and then came to join it to the semijoin's LHS.  That still gave
      the right answer as far as the semijoin itself was concerned, but would lead
      to incorrectly examining only an arbitrary one of the matchable rows from the
      unrelated relation(s).  The cause of this thinko was incorrect unification of
      the pre-8.4 logic for IN joins and OUTER joins --- the comparable case for
      outer joins can be handled after making the match test, but that's because
      there is nothing like the unique-ification escape hatch for outer joins.
      Per bug #4934 from Benjamin Reed.
      1ca695db
    • Andrew Dunstan's avatar
  9. 22 Jul, 2009 5 commits
  10. 21 Jul, 2009 6 commits
  11. 20 Jul, 2009 1 commit