1. 20 6月, 2012 2 次提交
    • P
      Remove confusing half sentence from legal notice · c521665b
      Peter Eisentraut 提交于
      pointed out by Stefan Kaltenbrunner
      c521665b
    • T
      Share RI trigger code between NO ACTION and RESTRICT cases. · fe3db740
      Tom Lane 提交于
      These triggers are identical except for whether ri_Check_Pk_Match is to be
      called, so factor out the common code to save a couple hundred lines.
      
      Also, eliminate null-column checks in ri_Check_Pk_Match, since they're
      duplicate with the calling functions and require unnecessary complication
      in its API statement.
      
      Simplify the way code is shared between RI_FKey_check_ins and
      RI_FKey_check_upd, too.
      fe3db740
  2. 19 6月, 2012 6 次提交
    • T
      Improve comments about why SET DEFAULT triggers must recheck for matches. · 48756be9
      Tom Lane 提交于
      I was confused about this, so try to make it clearer for the next person.
      
      (This seems like a fairly inefficient way of dealing with a corner case,
      but I don't have a better idea offhand.  Maybe if there were a way to turn
      off the RI_FKey_keyequal_upd_fk event filter temporarily?)
      48756be9
    • T
      Allow ON UPDATE/DELETE SET DEFAULT plans to be cached. · e8c9fd5f
      Tom Lane 提交于
      Once upon a time, somebody was worried that cached RI plans wouldn't get
      remade with new default values after ALTER TABLE ... SET DEFAULT, so they
      didn't allow caching of plans for ON UPDATE/DELETE SET DEFAULT actions.
      That time is long gone, though (and even at the time I doubt this was the
      greatest hazard posed by ALTER TABLE...).  So allow these triggers to cache
      their plans just like the others.
      
      The cache_plan argument to ri_PlanCheck is now vestigial, since there
      are no callers that don't pass "true"; but I left it alone in case there
      is any future need for it.
      e8c9fd5f
    • T
      Remove derived fields from RI_QueryKey, and do a bit of other cleanup. · 03a5ba24
      Tom Lane 提交于
      We really only need the foreign key constraint's OID and the query type
      code to uniquely identify each plan we are caching for FK checks.  The
      other stuff that was in the struct had no business being used as part of
      a hash key, and was all just being copied from struct RI_ConstraintInfo
      anyway.  Get rid of the unnecessary fields, and readjust various function
      APIs to make them use RI_ConstraintInfo not RI_QueryKey as info source.
      
      I'd be surprised if this makes any measurable performance difference,
      but it certainly feels cleaner.
      03a5ba24
    • P
      pg_dump: Add missing newlines at end of messages · e1e97e93
      Peter Eisentraut 提交于
      e1e97e93
    • T
      Update SQL spec references in ri_triggers code to match SQL:2008. · f9429746
      Tom Lane 提交于
      Now that what we're implementing isn't SQL92, we probably shouldn't cite
      chapter and verse in that spec anymore.  Also fix some comments that
      talked about MATCH FULL but in fact were in code that's also used for
      MATCH SIMPLE.
      
      No code changes in this commit, just comments.
      f9429746
    • T
      Change ON UPDATE SET NULL/SET DEFAULT referential actions to meet SQL spec. · c75be2ad
      Tom Lane 提交于
      Previously, when executing an ON UPDATE SET NULL or SET DEFAULT action for
      a multicolumn MATCH SIMPLE foreign key constraint, we would set only those
      referencing columns corresponding to referenced columns that were changed.
      This is what the SQL92 standard said to do --- but more recent versions
      of the standard say that all referencing columns should be set to null or
      their default values, no matter exactly which referenced columns changed.
      At least for SET DEFAULT, that is clearly saner behavior.  It's somewhat
      debatable whether it's an improvement for SET NULL, but it appears that
      other RDBMS systems read the spec this way.  So let's do it like that.
      
      This is a release-notable behavioral change, although considering that
      our documentation already implied it was done this way, the lack of
      complaints suggests few people use such cases.
      c75be2ad
  3. 18 6月, 2012 3 次提交
    • T
      Refer to the default foreign key match style as MATCH SIMPLE internally. · f5297bdf
      Tom Lane 提交于
      Previously we followed the SQL92 wording, "MATCH <unspecified>", but since
      SQL99 there's been a less awkward way to refer to the default style.
      
      In addition to the code changes, pg_constraint.confmatchtype now stores
      this match style as 's' (SIMPLE) rather than 'u' (UNSPECIFIED).  This
      doesn't affect pg_dump or psql because they use pg_get_constraintdef()
      to reconstruct foreign key definitions.  But other client-side code might
      examine that column directly, so this change will have to be marked as
      an incompatibility in the 9.3 release notes.
      f5297bdf
    • P
      Make documentation of --help and --version options more consistent · bb7520cc
      Peter Eisentraut 提交于
      Before, some places didn't document the short options (-? and -V),
      some documented both, some documented nothing, and they were listed in
      various orders.  Now this is hopefully more consistent and complete.
      bb7520cc
    • T
      Fix stats collector to recover nicely when system clock goes backwards. · 9e18eacb
      Tom Lane 提交于
      Formerly, if the system clock went backwards, the stats collector would
      fail to update the stats file any more until the clock reading again
      exceeds whatever timestamp was last written into the stats file.  Such
      glitches in the clock's behavior are not terribly unlikely on machines
      not using NTP.  Such a scenario has been observed to cause regression test
      failures in the buildfarm, and it could have bad effects on the behavior
      of autovacuum, so it seems prudent to install some defenses.
      
      We could directly detect the clock going backwards by adding
      GetCurrentTimestamp calls in the stats collector's main loop, but that
      would hurt performance on platforms where GetCurrentTimestamp is expensive.
      To minimize the performance hit in normal cases, adopt a more complicated
      scheme wherein backends check for clock skew when reading the stats file,
      and if they see it, signal the stats collector by sending an extra stats
      inquiry message.  The stats collector does an extra GetCurrentTimestamp
      only when it receives an inquiry with an apparently out-of-order
      timestamp.
      
      To avoid unnecessary GetCurrentTimestamp calls, expand the inquiry messages
      to carry the backend's current clock reading as well as its stats cutoff
      time.  The latter, being intentionally slightly in-the-past, would trigger
      more clock rechecks than we need if it were used for this purpose.
      
      We might want to backpatch this change at some point, but let's let it
      shake out in the buildfarm for awhile first.
      9e18eacb
  4. 17 6月, 2012 1 次提交
  5. 16 6月, 2012 5 次提交
  6. 15 6月, 2012 4 次提交
  7. 14 6月, 2012 16 次提交
    • R
      During transaction cleanup, release locks before deleting files. · cd800734
      Robert Haas 提交于
      There's no need to hold onto the locks until the files are needed,
      and by doing it this way, we reduce the impact on other backends who
      may be awaiting locks we hold.
      
      Noah Misch
      cd800734
    • R
      Add new function log_newpage_buffer. · 6cd015be
      Robert Haas 提交于
      When I implemented the ginbuildempty() function as part of
      implementing unlogged tables, I falsified the note in the header
      comment for log_newpage.  Although we could fix that up by changing
      the comment, it seems cleaner to add a new function which is
      specifically intended to handle this case.  So do that.
      6cd015be
    • R
      Remove misplaced sanity check from heap_create(). · a475c603
      Robert Haas 提交于
      Even when allow_system_table_mods is not set, we allow creation of any
      type of SQL object in pg_catalog, except for relations.  And you can
      get relations into pg_catalog, too, by initially creating them in some
      other schema and then moving them with ALTER .. SET SCHEMA.  So this
      restriction, which prevents relations (only) from being created in
      pg_catalog directly, is fairly pointless.  If we need a safety mechanism
      for this, it should be placed further upstream, so that it affects all
      SQL objects uniformly, and picks up both CREATE and SET SCHEMA.
      
      For now, just rip it out, per discussion with Tom Lane.
      a475c603
    • R
      Remove RELKIND_UNCATALOGED. · d2c86a1c
      Robert Haas 提交于
      This may have been important at some point in the past, but it no
      longer does anything useful.
      
      Review by Tom Lane.
      d2c86a1c
    • R
      Make \conninfo print SSL information. · 7582e0be
      Robert Haas 提交于
      Alastair Turner, per suggestion from Bruce Momjian.
      7582e0be
    • T
      Add 9.2 branch to git_changelog's list. · 80491a19
      Tom Lane 提交于
      80491a19
    • T
      Flesh out RELEASE_CHANGES instructions for branching in git. · f32609db
      Tom Lane 提交于
      We have this info in the wiki, but it should be here too.
      f32609db
    • T
      Stamp library minor versions for 9.3. · 357c5493
      Tom Lane 提交于
      This includes fixing the MSVC copy of ecpg/preproc's version info, which
      seems to have been overlooked repeatedly.  Can't we fix that so there are
      not two copies??
      357c5493
    • T
      Stamp HEAD as 9.3devel. · bed88fce
      Tom Lane 提交于
      Let the hacking begin ...
      bed88fce
    • T
      Revisit error message details for JSON input parsing. · 80edfd76
      Tom Lane 提交于
      Instead of identifying error locations only by line number (which could
      be entirely unhelpful with long input lines), provide a fragment of the
      input text too, placing this info in a new CONTEXT entry.  Make the
      error detail messages conform more closely to style guidelines, fix
      failure to expose some of them for translation, ensure compiler can
      check formats against supplied parameters.
      80edfd76
    • T
      Remove release note entry for reverted patch. · 0f0fba17
      Tom Lane 提交于
      0f0fba17
    • T
      Revert "Reduce checkpoints and WAL traffic on low activity database server" · b8b69d89
      Tom Lane 提交于
      This reverts commit 18fb9d8d.  Per
      discussion, it does not seem like a good idea to allow committed changes to
      go un-checkpointed indefinitely, as could happen in a low-traffic server;
      that makes us entirely reliant on the WAL stream with no redundancy that
      might aid data recovery in case of disk failure.
      
      This re-introduces the original problem of hot-standby setups generating a
      small continuing stream of WAL traffic even when idle, but there are other
      ways to address that without compromising crash recovery, so we'll revisit
      that issue in a future release cycle.
      b8b69d89
    • T
      Fix description of SQL-standard meaning of CREATE LOCAL TEMP TABLE. · 8b23db94
      Tom Lane 提交于
      I had this slightly wrong, as noted by Noah Misch.
      8b23db94
    • T
      Deprecate use of GLOBAL and LOCAL in temp table creation. · c3bc76bd
      Tom Lane 提交于
      Aside from adjusting the documentation to say that these are deprecated,
      we now report a warning (not an error) for use of GLOBAL, since it seems
      fairly likely that we might change that to request SQL-spec-compliant temp
      table behavior in the foreseeable future.  Although our handling of LOCAL
      is equally nonstandard, there is no evident interest in ever implementing
      SQL modules, and furthermore some other products interpret LOCAL as
      behaving the same way we do.  So no expectation of change and no warning
      for LOCAL; but it still seems a good idea to deprecate writing it.
      
      Noah Misch
      c3bc76bd
    • T
      Support Linux's oom_score_adj API as well as the older oom_adj API. · 93f4d7f8
      Tom Lane 提交于
      The simplest way to handle this is just to copy-and-paste the relevant
      code block in fork_process.c, so that's what I did. (It's possible that
      something more complicated would be useful to packagers who want to work
      with either the old or the new API; but at this point the number of such
      people is rapidly approaching zero, so let's just get the minimal thing
      done.)  Update relevant documentation as well.
      93f4d7f8
    • B
      In pg_upgrade, verify that the install user has the same oid on both · b9212e37
      Bruce Momjian 提交于
      clusters, and make sure the new cluster has no additional users.
      
      Backpatch to 9.1.
      b9212e37
  8. 13 6月, 2012 2 次提交
  9. 12 6月, 2012 1 次提交