1. 17 Sep, 2008 2 commits
  2. 16 Sep, 2008 3 commits
    • Tom Lane's avatar
      Clean up a couple of weird corner cases in interval parsing: make -yyyy-mm be · b73c0c2a
      Tom Lane authored
      interpreted as expected (the sign should affect months too), and get rid of
      hard-wired assumption that unmarked signed values must be hours (if integers)
      or seconds (if floats).  The former was just a bug in my previous patch,
      while the latter may have made sense at one time but seems illogical now
      that we support determination of the units from typmod information.
      Ron Mayer and myself.
      b73c0c2a
    • Tom Lane's avatar
      Widen the nLocks counts in local lock tables from int to int64. This · 30df79a7
      Tom Lane authored
      forestalls potential overflow when the same table (or other object, but
      usually tables) is accessed by very many successive queries within a single
      transaction.  Per report from Michael Milligan.
      
      Back-patch to 8.0, which is as far back as the patch conveniently applies.
      There have been no reports of overflow in pre-8.3 releases, but clearly the
      risk existed all along.  (Michael's report suggests that 8.3 may consume lock
      counts faster than prior releases, but with no test case to look at it's hard
      to be sure about that.  Widening the counts seems a good future-proofing
      measure in any event.)
      30df79a7
    • Tom Lane's avatar
  3. 15 Sep, 2008 8 commits
  4. 12 Sep, 2008 3 commits
  5. 11 Sep, 2008 4 commits
    • Tom Lane's avatar
      Add a duration option to pgbench, so that test length can be specified in seconds · cff4aa6a
      Tom Lane authored
      instead of by number of transactions to run.  Takahiro Itagaki
      cff4aa6a
    • Tom Lane's avatar
      Tighten up to_date/to_timestamp so that they are more likely to reject · 06edce4c
      Tom Lane authored
      erroneous input, rather than silently producing bizarre results as formerly
      happened.
      
      Brendan Jurd
      06edce4c
    • Tom Lane's avatar
      Adjust the parser to accept the typename syntax INTERVAL ... SECOND(n) · 70530c80
      Tom Lane authored
      and the literal syntax INTERVAL 'string' ... SECOND(n), as required by the
      SQL standard.  Our old syntax put (n) directly after INTERVAL, which was
      a mistake, but will still be accepted for backward compatibility as well
      as symmetry with the TIMESTAMP cases.
      
      Change intervaltypmodout to show it in the spec's way, too.  (This could
      potentially affect clients, if there are any that analyze the typmod of an
      INTERVAL in any detail.)
      
      Also fix interval input to handle 'min:sec.frac' properly; I had overlooked
      this case in my previous patch.
      
      Document the use of the interval fields qualifier, which up to now we had
      never mentioned in the docs.  (I think the omission was intentional because
      it didn't work per spec; but it does now, or at least close enough to be
      credible.)
      70530c80
    • Alvaro Herrera's avatar
      Initialize the minimum frozen Xid in vac_update_datfrozenxid using · d53a5668
      Alvaro Herrera authored
      GetOldestXmin() instead of RecentGlobalXmin; this is safer because we do not
      depend on the latter being correctly set elsewhere, and while it is more
      expensive, this code path is not performance-critical.  This is a real
      risk for autovacuum, because it can execute whole cycles without doing
      a single vacuum, which would mean that RecentGlobalXmin would stay at its
      initialization value, FirstNormalTransactionId, causing a bogus value to be
      inserted in pg_database.  This bug could explain some recent reports of
      failure to truncate pg_clog.
      
      At the same time, change the initialization of RecentGlobalXmin to
      InvalidTransactionId, and ensure that it's set to something else whenever
      it's going to be used.  Using it as FirstNormalTransactionId in HOT page
      pruning could incur in data loss.  InitPostgres takes care of setting it
      to a valid value, but the extra checks are there to prevent "special"
      backends from behaving in unusual ways.
      
      Per Tom Lane's detailed problem dissection in 29544.1221061979@sss.pgh.pa.us
      d53a5668
  6. 10 Sep, 2008 5 commits
  7. 09 Sep, 2008 2 commits
  8. 08 Sep, 2008 4 commits
  9. 07 Sep, 2008 4 commits
  10. 06 Sep, 2008 2 commits
    • Tom Lane's avatar
      Adjust psql's new \ef command to present an empty CREATE FUNCTION template · 409c144d
      Tom Lane authored
      for editing if no function name is specified.  This seems a much cleaner way
      to offer that functionality than the original patch had.  In passing,
      de-clutter the error displays that are given for a bogus function-name
      argument, and standardize on "$function$" as the default delimiter for the
      function body.  (The original coding would use the shortest possible
      dollar-quote delimiter, which seems to create unnecessarily high risk of
      later conflicts with the user-modified function body.)
      409c144d
    • Tom Lane's avatar
      Implement a psql command "\ef" to edit the definition of a function. · 2c863ca8
      Tom Lane authored
      In support of that, create a backend function pg_get_functiondef().
      The psql command is functional but maybe a bit rough around the edges...
      
      Abhijit Menon-Sen
      2c863ca8
  11. 05 Sep, 2008 3 commits
    • Bruce Momjian's avatar
    • Tom Lane's avatar
      Fix an oversight in the 8.2 patch that improved mergejoin performance by · e540b972
      Tom Lane authored
      inserting a materialize node above an inner-side sort node, when the sort is
      expected to spill to disk.  (The materialize protects the sort from having
      to support mark/restore, allowing it to do its final merge pass on-the-fly.)
      We neglected to teach cost_mergejoin about that hack, so it was failing to
      include the materialize's costs in the estimated cost of the mergejoin.
      The materialize's costs are generally going to be pretty negligible in
      comparison to the sort's, so this is only a small error and probably not
      worth back-patching; but it's still wrong.
      
      In the similar case where a materialize is inserted to protect an inner-side
      node that can't do mark/restore at all, it's still true that the materialize
      should not spill to disk, and so we should cost it cheaply rather than
      expensively.
      
      Noted while thinking about a question from Tom Raney.
      e540b972
    • Peter Eisentraut's avatar