1. 21 Mar, 2007 7 commits
  2. 20 Mar, 2007 5 commits
  3. 19 Mar, 2007 7 commits
    • Jan Wieck's avatar
      Changes pg_trigger and extend pg_rewrite in order to allow triggers and · 0fe16500
      Jan Wieck authored
      rules to be defined with different, per session controllable, behaviors
      for replication purposes.
      
      This will allow replication systems like Slony-I and, as has been stated
      on pgsql-hackers, other products to control the firing mechanism of
      triggers and rewrite rules without modifying the system catalog directly.
      
      The firing mechanisms are controlled by a new superuser-only GUC
      variable, session_replication_role, together with a change to
      pg_trigger.tgenabled and a new column pg_rewrite.ev_enabled. Both
      columns are a single char data type now (tgenabled was a bool before).
      The possible values in these attributes are:
      
           'O' - Trigger/Rule fires when session_replication_role is "origin"
                 (default) or "local". This is the default behavior.
      
           'D' - Trigger/Rule is disabled and fires never
      
           'A' - Trigger/Rule fires always regardless of the setting of
                 session_replication_role
      
           'R' - Trigger/Rule fires when session_replication_role is "replica"
      
      The GUC variable can only be changed as long as the system does not have
      any cached query plans. This will prevent changing the session role and
      accidentally executing stored procedures or functions that have plans
      cached that expand to the wrong query set due to differences in the rule
      firing semantics.
      
      The SQL syntax for changing a triggers/rules firing semantics is
      
           ALTER TABLE <tabname> <when> TRIGGER|RULE <name>;
      
           <when> ::= ENABLE | ENABLE ALWAYS | ENABLE REPLICA | DISABLE
      
      psql's \d command as well as pg_dump are extended in a backward
      compatible fashion.
      
      Jan
      0fe16500
    • Bruce Momjian's avatar
      Remove last line of patch license, per Zeugswetter Andreas: · e927f8f1
      Bruce Momjian authored
      "If the patch is not BSD-licensed, it will be rejected."
      e927f8f1
    • Tom Lane's avatar
      Further buildfarm experience shows that actually we can't run the plancache · e28e318c
      Tom Lane authored
      test in parallel with the rules test at all, because the former wants to
      create a couple of temp views, which can sometimes show up in the latter's
      output.  Let's try it in the next parallel group instead.
      e28e318c
    • Tom Lane's avatar
      Fix 8.2 breakage of domains over array types, and add a regression test case · 9bc933b2
      Tom Lane authored
      to cover it.  Per report from Anton Pikhteryev.
      9bc933b2
    • Bruce Momjian's avatar
      Add URL for: · 79929fff
      Bruce Momjian authored
      * Simplify ability to create partitioned tables
      >   http://archives.postgresql.org/pgsql-hackers/2007-03/msg00375.php
      79929fff
    • Bruce Momjian's avatar
      Add URL for: · 00c56bb7
      Bruce Momjian authored
      * Allow sequential scans to take advantage of other concurrent
        sequential scans, also called "Synchronised Scanning"
      
        http://archives.postgresql.org/pgsql-hackers/2007-03/msg00415.php
      00c56bb7
    • Magnus Hagander's avatar
      62df7c31
  4. 18 Mar, 2007 3 commits
  5. 17 Mar, 2007 10 commits
  6. 16 Mar, 2007 5 commits
  7. 15 Mar, 2007 1 commit
    • Tom Lane's avatar
      Make use of plancache module for SPI plans. In particular, since plpgsql · 95f6d2d2
      Tom Lane authored
      uses SPI plans, this finally fixes the ancient gotcha that you can't
      drop and recreate a temp table used by a plpgsql function.
      
      Along the way, clean up SPI's API a little bit by declaring SPI plan
      pointers as "SPIPlanPtr" instead of "void *".  This is cosmetic but
      helps to forestall simple programming mistakes.  (I have changed some
      but not all of the callers to match; there are still some "void *"'s
      in contrib and the PL's.  This is intentional so that we can see if
      anyone's compiler complains about it.)
      95f6d2d2
  8. 14 Mar, 2007 2 commits
    • Tom Lane's avatar
      Fix a longstanding bug in VACUUM FULL's handling of update chains. The code · d3ff1801
      Tom Lane authored
      did not expect that a DEAD tuple could follow a RECENTLY_DEAD tuple in an
      update chain, but because the OldestXmin rule for determining deadness is a
      simplification of reality, it is possible for this situation to occur
      (implying that the RECENTLY_DEAD tuple is in fact dead to all observers,
      but this patch does not attempt to exploit that).  The code would follow a
      chain forward all the way, but then stop before a DEAD tuple when backing
      up, meaning that not all of the chain got moved.  This could lead to copying
      the chain multiple times (resulting in duplicate copies of the live tuple at
      its end), or leaving dangling index entries behind (which, aside from
      generating warnings from later vacuums, creates a risk of wrong query
      results or bogus duplicate-key errors once the heap slot the index entry
      points to is repopulated).
      
      The fix is to recheck HeapTupleSatisfiesVacuum while following a chain
      forward, and to stop if a DEAD tuple is reached.  Each contiguous group
      of RECENTLY_DEAD tuples will therefore be copied as a separate chain.
      The patch also adds a couple of extra sanity checks to verify correct
      behavior.
      
      Per report and test case from Pavan Deolasee.
      d3ff1801
    • Tom Lane's avatar
      Arrange to install a "posixrules" entry in our timezone database, so that · 0169c354
      Tom Lane authored
      POSIX-style timezone specs that don't exactly match any database entry will
      be treated as having correct USA DST rules.  Also, document that this can
      be changed if you want to use some other DST rules with a POSIX zone spec.
      
      We could consider changing localtime.c's TZDEFRULESTRING, but since that
      facility can only deal with one DST transition rule, it seems fairly useless
      now; might as well just plan to override it using a "posixrules" entry.
      
      Backpatch as far as 8.0.  There isn't much we can do in 7.x ... either your
      libc gets it right, or it doesn't.
      0169c354