Skip to content
Snippets Groups Projects
  1. Jun 21, 2012
    • Tom Lane's avatar
      Remove incomplete/incorrect support for zero-column foreign keys. · dfd9c116
      Tom Lane authored
      The original coding in ri_triggers.c had partial support for the concept of
      zero-column foreign key constraints.  But this is not defined in the SQL
      standard, nor was it ever allowed by any other part of Postgres, nor was it
      very fully implemented even here (eg there was no support for preventing
      PK-table deletions that would violate the constraint).  Doesn't seem very
      useful to carry 100-plus lines of code for a corner case that no one is
      interested in making work.  Instead, just add a check that the column list
      read from pg_constraint is non-empty.
      dfd9c116
    • Tom Lane's avatar
      Increase MAX_SYSCACHE_CALLBACKS from 20 to 32. · 0ce4459a
      Tom Lane authored
      By my count there are 18 callers of CacheRegisterSyscacheCallback in the
      core code in HEAD, so we are potentially leaving as few as 2 slots for any
      add-on code to use (though possibly not all these callers would actually
      activate in any particular session).  That doesn't seem like a lot of
      headroom, so let's pump it up a little.
      0ce4459a
  2. Jun 20, 2012
    • Tom Lane's avatar
      Cache the results of ri_FetchConstraintInfo in a backend-local cache. · 45ba424f
      Tom Lane authored
      Extracting data from pg_constraint turned out to take as much as 10% of the
      runtime in a bulk-update case where the foreign key column wasn't changing,
      because we did it over again for each tuple.  Fix that by maintaining a
      backend-local cache of the results.  This is really a pretty small patch,
      but converting the trigger functions to work with pointers rather than
      local struct variables requires a lot of mechanical changes.
      45ba424f
    • Tom Lane's avatar
      Improve tests for whether we can skip queueing RI enforcement triggers. · cfa0f425
      Tom Lane authored
      During an update of a PK row, we can skip firing the RI trigger if any old
      key value is NULL, because then the row could not have had any matching
      rows in the FK table.  Conversely, during an update of an FK row, the
      outcome is determined if any new key value is NULL.  In either case it
      becomes unnecessary to compare individual key values.
      
      This patch was inspired by discussion of Vik Reykja's patch to use IS NOT
      DISTINCT semantics for the key comparisons.  In the event there is no need
      for that and so this patch looks nothing like his, but he should still get
      credit for having re-opened consideration of the trigger skip logic.
      cfa0f425
    • Tom Lane's avatar
      Add pgbench option to add foreign key constraints to the standard scenario. · afe1c51c
      Tom Lane authored
      The option --foreign-keys, used at initialization time, will create foreign
      key constraints for the columns that represent references to other tables'
      primary keys.  This can help in benchmarking FK performance.
      
      Jeff Janes
      afe1c51c
  3. Jun 19, 2012
    • Alvaro Herrera's avatar
      pg_dump: Fix verbosity level in LO progress messages · 11b335ac
      Alvaro Herrera authored
      In passing, reword another instance of the same message that was
      gratuitously different.
      
      Author: Josh Kupershmidt
      after a bug report by Bosco Rama
      11b335ac
    • Peter Eisentraut's avatar
      Remove confusing half sentence from legal notice · c521665b
      Peter Eisentraut authored
      pointed out by Stefan Kaltenbrunner
      c521665b
    • Tom Lane's avatar
      Share RI trigger code between NO ACTION and RESTRICT cases. · fe3db740
      Tom Lane authored
      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
    • Tom Lane's avatar
      Improve comments about why SET DEFAULT triggers must recheck for matches. · 48756be9
      Tom Lane authored
      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
    • Tom Lane's avatar
      Allow ON UPDATE/DELETE SET DEFAULT plans to be cached. · e8c9fd5f
      Tom Lane authored
      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
    • Tom Lane's avatar
      Remove derived fields from RI_QueryKey, and do a bit of other cleanup. · 03a5ba24
      Tom Lane authored
      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
  4. Jun 18, 2012
    • Peter Eisentraut's avatar
      e1e97e93
    • Tom Lane's avatar
      Update SQL spec references in ri_triggers code to match SQL:2008. · f9429746
      Tom Lane authored
      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
    • Tom Lane's avatar
      Change ON UPDATE SET NULL/SET DEFAULT referential actions to meet SQL spec. · c75be2ad
      Tom Lane authored
      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
    • Tom Lane's avatar
      Refer to the default foreign key match style as MATCH SIMPLE internally. · f5297bdf
      Tom Lane authored
      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
    • Peter Eisentraut's avatar
      Make documentation of --help and --version options more consistent · bb7520cc
      Peter Eisentraut authored
      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
  5. Jun 17, 2012
    • Tom Lane's avatar
      Fix stats collector to recover nicely when system clock goes backwards. · 9e18eacb
      Tom Lane authored
      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
    • Magnus Hagander's avatar
      Reorder basebackup options, to list pg_basebackup first · 920febda
      Magnus Hagander authored
      Since this is the easy way of doing it, it should be listed first. All
      the old information is retained for those who want the more advanced way.
      
      Also adds a subheading for compressing logs, that seems to have been missing
      920febda
  6. Jun 16, 2012
  7. Jun 15, 2012
    • Peter Eisentraut's avatar
      Improve reporting of permission errors for array types · 15b1918e
      Peter Eisentraut authored
      Because permissions are assigned to element types, not array types,
      complaining about permission denied on an array type would be
      misleading to users.  So adjust the reporting to refer to the element
      type instead.
      
      In order not to duplicate the required logic in two dozen places,
      refactor the permission denied reporting for types a bit.
      
      pointed out by Yeb Havinga during the review of the type privilege
      feature
      15b1918e
    • Peter Eisentraut's avatar
      Add more message pluralization · d933092e
      Peter Eisentraut authored
      Even though we can't do much about the case with multiple plurals in
      one sentence, we can fix the other cases.
      d933092e
  8. Jun 14, 2012
Loading