1. 10 Jun, 2011 6 commits
    • Heikki Linnakangas's avatar
      Fix locking while setting flags in MySerializableXact. · cb2d158c
      Heikki Linnakangas authored
      Even if a flag is modified only by the backend owning the transaction, it's
      not safe to modify it without a lock. Another backend might be setting or
      clearing a different flag in the flags field concurrently, and that
      operation might be lost because setting or clearing a bit in a word is not
      atomic.
      
      Make did-write flag a simple backend-private boolean variable, because it
      was only set or tested in the owning backend (except when committing a
      prepared transaction, but it's not worthwhile to optimize for the case of a
      read-only prepared transaction). This also eliminates the need to add
      locking where that flag is set.
      
      Also, set the did-write flag when doing DDL operations like DROP TABLE or
      TRUNCATE -- that was missed earlier.
      cb2d158c
    • Alvaro Herrera's avatar
      Add comment about pg_ctl stop · d69149ed
      Alvaro Herrera authored
      d69149ed
    • Alvaro Herrera's avatar
      Use "transient" files for blind writes, take 2 · fba105b1
      Alvaro Herrera authored
      "Blind writes" are a mechanism to push buffers down to disk when
      evicting them; since they may belong to different databases than the one
      a backend is connected to, the backend does not necessarily have a
      relation to link them to, and thus no way to blow them away.  We were
      keeping those files open indefinitely, which would cause a problem if
      the underlying table was deleted, because the operating system would not
      be able to reclaim the disk space used by those files.
      
      To fix, have bufmgr mark such files as transient to smgr; the lower
      layer is allowed to close the file descriptor when the current
      transaction ends.  We must be careful to have any other access of the
      file to remove the transient markings, to prevent unnecessary expensive
      system calls when evicting buffers belonging to our own database (which
      files we're likely to require again soon.)
      
      This commit fixes a bug in the previous one, which neglected to cleanly
      handle the LRU ring that fd.c uses to manage open files, and caused an
      unacceptable failure just before beta2 and was thus reverted.
      fba105b1
    • Alvaro Herrera's avatar
    • Heikki Linnakangas's avatar
      Small comment fixes and enhancements. · c79c570b
      Heikki Linnakangas authored
      c79c570b
    • Bruce Momjian's avatar
      bb8f0c4b
  2. 09 Jun, 2011 14 commits
  3. 08 Jun, 2011 6 commits
    • Tom Lane's avatar
      Make citext's equality and hashing functions collation-insensitive. · 3ebc061c
      Tom Lane authored
      This is an ugly hack to get around the fact that significant parts of the
      core backend assume they don't need to worry about passing collation to
      equality and hashing functions.  That's true for the core string datatypes,
      but citext should ideally have equality behavior that depends on the
      specified collation's LC_CTYPE.  However, there's no chance of fixing the
      core before 9.2, so we'll have to live with this compromise arrangement for
      now.  Per bug #6053 from Regina Obe.
      
      The code changes in this commit should be reverted in full once the core
      code is up to speed, but be careful about reverting the docs changes:
      I fixed a number of obsolete statements while at it.
      3ebc061c
    • Peter Eisentraut's avatar
      Reorder pg_ctl promote after pg_ctl status · 1bcdd663
      Peter Eisentraut authored
      Since start/stop/restart/reload/status is a kind of standard command
      set, it seems odd to insert the special-purpose "promote" in between
      the closely related "restart" and "reload".  So put it after "status"
      in code and documentation.
      
      Put the documentation of the -U option in some sensible place.
      
      Rewrite the synopsis sentence in help and documentation to make it
      less of a growing mouthful.
      1bcdd663
    • Tom Lane's avatar
      Allow domains over arrays to match ANYARRAY parameters again. · b7e8feb3
      Tom Lane authored
      This use-case was broken in commit 529cb267
      of 2010-10-21, in which I commented "For the moment, we just forbid such
      matching.  We might later wish to insert an automatic downcast to the
      underlying array type, but such a change should also change matching of
      domains to ANYELEMENT for consistency".  We still lack consensus about what
      to do with ANYELEMENT; but not matching ANYARRAY is a clear loss of
      functionality compared to prior releases, so let's go ahead and make that
      happen.  Per complaint from Regina Obe and extensive subsequent discussion.
      b7e8feb3
    • Heikki Linnakangas's avatar
      Make DDL operations play nicely with Serializable Snapshot Isolation. · 8f9622bb
      Heikki Linnakangas authored
      Truncating or dropping a table is treated like deletion of all tuples, and
      check for conflicts accordingly. If a table is clustered or rewritten by
      ALTER TABLE, all predicate locks on the heap are promoted to relation-level
      locks, because the tuple or page ids of any existing tuples will change and
      won't be valid after rewriting the table. Arguably ALTER TABLE should be
      treated like a mass-UPDATE of every row, but if you e.g change the datatype
      of a column, you could also argue that it's just a change to the physical
      layout, not a logical change. Reindexing promotes all locks on the index to
      relation-level lock on the heap.
      
      Kevin Grittner, with a lot of cosmetic changes by me.
      8f9622bb
    • Robert Haas's avatar
      Complain politely about access temp/unlogged tables during recovery. · 16925c1e
      Robert Haas authored
      This has never been supported, but we previously let md.c issue the
      complaint for us at whatever point we tried to examine the backing file.
      Now we print a nicer error message.
      
      Per bug #6041, reported by Emanuel, and extensive discussion with Tom
      Lane over where to put the check.
      16925c1e
    • Alvaro Herrera's avatar
      Revert psql bits to display NOT VALID for FKs · 135a5079
      Alvaro Herrera authored
      These are superseded by pg_get_constraintdef's ability to display the
      same when appropriate, which is a better place to do it anyway.
      135a5079
  4. 07 Jun, 2011 2 commits
    • Heikki Linnakangas's avatar
    • Tom Lane's avatar
      Fix rewriter to cope (more or less) with CTEs in the query being rewritten. · fc1286d3
      Tom Lane authored
      Since the original implementation of CTEs only allowed them in SELECT
      queries, the rule rewriter did not expect to find any CTEs in statements
      being rewritten by ON INSERT/UPDATE/DELETE rules.  We had dealt with this
      to some extent but the code was still several bricks shy of a load, as
      illustrated in bug #6051 from Jehan-Guillaume de Rorthais.
      
      In particular, we have to be able to copy CTEs from the original query's
      cteList into that of a rule action, in case the rule action references the
      CTE (which it pretty much always will).  This also implies we were doing
      things in the wrong order in RewriteQuery: we have to recursively rewrite
      the CTE queries before expanding the main query, so that we have the
      rewritten queries available to copy.
      
      There are unpleasant limitations yet to resolve here, but at least we now
      throw understandable FEATURE_NOT_SUPPORTED errors for them instead of just
      failing with bizarre implementation-dependent errors.  In particular, we
      can't handle propagating the same CTE into multiple post-rewrite queries
      (because then the CTE would be evaluated multiple times), and we can't cope
      with conflicts between CTE names in the original query and in the rule
      actions.
      fc1286d3
  5. 06 Jun, 2011 1 commit
  6. 04 Jun, 2011 5 commits
  7. 03 Jun, 2011 5 commits
    • Alvaro Herrera's avatar
      Fix pg_get_constraintdef to cope with NOT VALID constraints · 04841751
      Alvaro Herrera authored
      This case was missed when NOT VALID constraints were first introduced in
      commit 722bf701 by Simon Riggs on
      2011-02-08.  Among other things, it causes pg_dump to omit the NOT VALID
      flag when dumping such constraints, which may cause them to fail to
      load afterwards, if they contained values failing the constraint.
      
      Per report from Thom Brown.
      04841751
    • Tom Lane's avatar
      Fix failure to check whether a rowtype's component types are sortable. · ea8e42f3
      Tom Lane authored
      The existence of a btree opclass accepting composite types caused us to
      assume that every composite type is sortable.  This isn't true of course;
      we need to check if the column types are all sortable.  There was logic
      for this for the case of array comparison (ie, check that the element
      type is sortable), but we missed the point for rowtypes.  Per Teodor's
      report of an ANALYZE failure for an unsortable composite type.
      
      Rather than just add some more ad-hoc logic for this, I moved knowledge of
      the issue into typcache.c.  The typcache will now only report out array_eq,
      record_cmp, and friends as usable operators if the array or composite type
      will work with those functions.
      
      Unfortunately we don't have enough info to do this for anonymous RECORD
      types; in that case, just assume it will work, and take the runtime failure
      as before if it doesn't.
      
      This patch might be a candidate for back-patching at some point, but
      given the lack of complaints from the field, I'd rather just test it in
      HEAD for now.
      
      Note: most of the places touched in this patch will need further work
      when we get around to supporting hashing of record types.
      ea8e42f3
    • Peter Eisentraut's avatar
      Truncate id to <=44 characters · 3ece3913
      Peter Eisentraut authored
      This is the original DocBook SGML limit, but apparently most
      installations have changed it or ignore it, which is why few people
      have run into this problem.
      
      pointed out by Brendan Jurd
      3ece3913
    • Heikki Linnakangas's avatar
      SSI comment fixes and enhancements. Notably, document that the conflict-out · c8630919
      Heikki Linnakangas authored
      flag actually means that the transaction has a conflict out to a transaction
      that committed before the flagged transaction.
      
      Kevin Grittner
      c8630919
    • Tom Lane's avatar
      52caa355
  8. 02 Jun, 2011 1 commit