1. 14 Dec, 2013 1 commit
    • Tom Lane's avatar
      Fix inherited UPDATE/DELETE with UNION ALL subqueries. · c03ad560
      Tom Lane authored
      Fix an oversight in commit b3aaf908: we do
      indeed need to process the planner's append_rel_list when copying RTE
      subqueries, because if any of them were flattenable UNION ALL subqueries,
      the append_rel_list shows which subquery RTEs were pulled up out of which
      other ones.  Without this, UNION ALL subqueries aren't correctly inserted
      into the update plans for inheritance child tables after the first one,
      typically resulting in no update happening for those child table(s).
      Per report from Victor Yegorov.
      
      Experimentation with this case also exposed a fault in commit
      a7b96538: if an inherited UPDATE/DELETE
      was proven totally dummy by constraint exclusion, we might arrive at
      add_rtes_to_flat_rtable with root->simple_rel_array being NULL.  This
      should be interpreted as not having any RelOptInfos.  I chose to code
      the guard as a check against simple_rel_array_size, so as to also
      provide some protection against indexing off the end of the array.
      
      Back-patch to 9.2 where the faulty code was added.
      c03ad560
  2. 13 Dec, 2013 9 commits
    • Alvaro Herrera's avatar
      Fix typo · 60eea378
      Alvaro Herrera authored
      60eea378
    • Alvaro Herrera's avatar
      Rework MultiXactId cache code · d881dd62
      Alvaro Herrera authored
      The original performs too poorly; in some scenarios it shows way too
      high while profiling.  Try to make it a bit smarter to avoid excessive
      cosst.  In particular, make it have a maximum size, and have entries be
      sorted in LRU order; once the max size is reached, evict the oldest
      entry to avoid it from growing too large.
      
      Per complaint from Andres Freund in connection with new tuple freezing
      code.
      d881dd62
    • Tom Lane's avatar
      Add HOLD/RESUME_INTERRUPTS in HandleCatchupInterrupt/HandleNotifyInterrupt. · 2efc6dc2
      Tom Lane authored
      This prevents a possible longjmp out of the signal handler if a timeout
      or SIGINT occurs while something within the handler has transiently set
      ImmediateInterruptOK.  For safety we must hold off the timeout or cancel
      error until we're back in mainline, or at least till we reach the end of
      the signal handler when ImmediateInterruptOK was true at entry.  This
      syncs these functions with the logic now present in handle_sig_alarm.
      
      AFAICT there is no live bug here in 9.0 and up, because I don't think we
      currently can wait for any heavyweight lock inside these functions, and
      there is no other code (except read-from-client) that will turn on
      ImmediateInterruptOK.  However, that was not true pre-9.0: in older
      branches ProcessIncomingNotify might block trying to lock pg_listener, and
      then a SIGINT could lead to undesirable control flow.  It might be all
      right anyway given the relatively narrow code ranges in which NOTIFY
      interrupts are enabled, but for safety's sake I'm back-patching this.
      2efc6dc2
    • Heikki Linnakangas's avatar
      Fix more instances of "the the" in comments. · dde62825
      Heikki Linnakangas authored
      Plus one instance of "to to" in the docs.
      dde62825
    • Tom Lane's avatar
      Don't let timeout interrupts happen unless ImmediateInterruptOK is set. · e8312b4f
      Tom Lane authored
      Serious oversight in commit 16e1b7a1:
      we should not allow an interrupt to take control away from mainline code
      except when ImmediateInterruptOK is set.  Just to be safe, let's adopt
      the same save-clear-restore dance that's been used for many years in
      HandleCatchupInterrupt and HandleNotifyInterrupt, so that nothing bad
      happens if a timeout handler invokes code that tests or even manipulates
      ImmediateInterruptOK.
      
      Per report of "stuck spinlock" failures from Christophe Pettus, though
      many other symptoms are possible.  Diagnosis by Andres Freund.
      e8312b4f
    • Heikki Linnakangas's avatar
      Add GUC to enable WAL-logging of hint bits, even with checksums disabled. · 50e54709
      Heikki Linnakangas authored
      WAL records of hint bit updates is useful to tools that want to examine
      which pages have been modified. In particular, this is required to make
      the pg_rewind tool safe (without checksums).
      
      This can also be used to test how much extra WAL-logging would occur if
      you enabled checksums, without actually enabling them (which you can't
      currently do without re-initdb'ing).
      
      Sawada Masahiko, docs by Samrat Revagade. Reviewed by Dilip Kumar, with
      further changes by me.
      50e54709
    • Magnus Hagander's avatar
      Fix double "the" in the documentation · 56afe850
      Magnus Hagander authored
      Erik Rijkers
      56afe850
    • Heikki Linnakangas's avatar
      Fix WAL-logging of setting the visibility map bit. · a49633d8
      Heikki Linnakangas authored
      The operation that removes the remaining dead tuples from the page must
      be WAL-logged before the setting of the VM bit. Otherwise, if you replay
      the WAL to between those two records, you end up with the VM bit set, but
      the dead tuples are still there.
      
      Backpatch to 9.3, where this bug was introduced.
      a49633d8
    • Peter Eisentraut's avatar
      configure: Allow adding a custom string to PG_VERSION · 46328916
      Peter Eisentraut authored
      This can be used to mark custom built binaries with an extra version
      string such as a git describe identifier or distribution package release
      version.
      
      From: Oskari Saarenmaa <os@ohmu.fi>
      46328916
  3. 12 Dec, 2013 7 commits
  4. 11 Dec, 2013 11 commits
    • Tom Lane's avatar
      Add a regression test case for plpython function returning setof RECORD. · 6bff0e7d
      Tom Lane authored
      We had coverage for functions returning setof a named composite type,
      but not for anonymous records, which is a somewhat different code path.
      In view of recent crash report from Sergey Konoplev, this seems worth
      testing, though I doubt there's any deterministic bug here today.
      6bff0e7d
    • Simon Riggs's avatar
      Regression tests for SCHEMA commands · cf589c9c
      Simon Riggs authored
      Hari Babu Kommi reviewed by David Rowley
      cf589c9c
    • Simon Riggs's avatar
      Regression tests for ALTER TABLESPACE RENAME,OWNER · b921a26f
      Simon Riggs authored
      Hari Babu Kommi reviewed by David Rowley
      b921a26f
    • Tom Lane's avatar
      Tweak placement of explicit ANALYZE commands in the regression tests. · b5e0a2a3
      Tom Lane authored
      Make the COPY test, which loads most of the large static tables used in
      the tests, also explicitly ANALYZE those tables.  This allows us to get
      rid of various ad-hoc, and rather redundant, ANALYZE commands that had
      gotten stuck into various test scripts over time to ensure we got
      consistent plan choices.  (We could have done a database-wide ANALYZE,
      but that would cause stats to get attached to the small static tables
      too, which results in plan changes compared to the historical behavior.
      I'm not sure that's a good idea, so not going that far for now.)
      
      Back-patch to 9.0, since 9.0 and 9.1 are currently sometimes failing
      regression tests for lack of an "ANALYZE tenk1" in the subselect test.
      There's no need for this in 8.4 since we didn't print any plans back
      then.
      b5e0a2a3
    • Robert Haas's avatar
      Under wal_level=logical, when saving old tuples, always save OID. · 60dd40bb
      Robert Haas authored
      There's no real point in not doing this.  It doesn't cost anything
      in performance or space.  So let's go wild.
      
      Andres Freund, with substantial editing as to style by me.
      60dd40bb
    • Kevin Grittner's avatar
      Add table name to VACUUM statement in matview.c. · 09df854b
      Kevin Grittner authored
      The test only needs the one table to be vacuumed.  Vacuuming the
      database may affect other tests.
      
      Per gripe from Tom Lane.  Back-patch to 9.3, where the test was
      was added.
      09df854b
    • Peter Eisentraut's avatar
      PL/Perl: Add event trigger support · e5dc4cc2
      Peter Eisentraut authored
      From: Dimitri Fontaine <dimitri@2ndQuadrant.fr>
      e5dc4cc2
    • Robert Haas's avatar
      Add a new option, -g, to createuser, to add membership in a role. · 6bea96dd
      Robert Haas authored
      Chistopher Browne, reviewed by Sameer Thakur, Amit Kapila, and
      Peter Eisentraut.
      6bea96dd
    • Peter Eisentraut's avatar
      doc: Fix DocBook table column count declaration · a06af436
      Peter Eisentraut authored
      This was broken in d6464fdc.
      a06af436
    • Robert Haas's avatar
      Add a new reloption, user_catalog_table. · 66abc260
      Robert Haas authored
      When this reloption is set and wal_level=logical is configured,
      we'll record the CIDs stamped by inserts, updates, and deletes to
      the table just as we would for an actual catalog table.  This will
      allow logical decoding to use historical MVCC snapshots to access
      such tables just as they access ordinary catalog tables.
      
      Replication solutions built around the logical decoding machinery
      will likely need to set this operation for their configuration
      tables; it might also be needed by extensions which perform table
      access in their output functions.
      
      Andres Freund, reviewed by myself and others.
      66abc260
    • Robert Haas's avatar
      Add new wal_level, logical, sufficient for logical decoding. · e55704d8
      Robert Haas authored
      When wal_level=logical, we'll log columns from the old tuple as
      configured by the REPLICA IDENTITY facility added in commit
      07cacba9.  This makes it possible
      a properly-configured logical replication solution to correctly
      follow table updates even if they change the chosen key columns,
      or, with REPLICA IDENTITY FULL, even if the table has no key at
      all.  Note that updates which do not modify the replica identity
      column won't log anything extra, making the choice of a good key
      (i.e. one that will rarely be changed) important to performance
      when wal_level=logical is configured.
      
      Each insert, update, or delete to a catalog table will also log
      the CMIN and/or CMAX values of stamped by the current transaction.
      This is necessary because logical decoding will require access to
      historical snapshots of the catalog in order to decode some data
      types, and the CMIN/CMAX values that we may need in order to judge
      row visibility may have been overwritten by the time we need them.
      
      Andres Freund, reviewed in various versions by myself, Heikki
      Linnakangas, KONDO Mitsumasa, and many others.
      e55704d8
  5. 10 Dec, 2013 2 commits
    • Tom Lane's avatar
      Fix possible crash with nested SubLinks. · 9ec6199d
      Tom Lane authored
      An expression such as WHERE (... x IN (SELECT ...) ...) IN (SELECT ...)
      could produce an invalid plan that results in a crash at execution time,
      if the planner attempts to flatten the outer IN into a semi-join.
      This happens because convert_testexpr() was not expecting any nested
      SubLinks and would wrongly replace any PARAM_SUBLINK Params belonging
      to the inner SubLink.  (I think the comment denying that this case could
      happen was wrong when written; it's certainly been wrong for quite a long
      time, since very early versions of the semijoin flattening logic.)
      
      Per report from Teodor Sigaev.  Back-patch to all supported branches.
      9ec6199d
    • Noah Misch's avatar
      Rename TABLE() to ROWS FROM(). · 53685d79
      Noah Misch authored
      SQL-standard TABLE() is a subset of UNNEST(); they deal with arrays and
      other collection types.  This feature, however, deals with set-returning
      functions.  Use a different syntax for this feature to keep open the
      possibility of implementing the standard TABLE().
      53685d79
  6. 09 Dec, 2013 3 commits
  7. 08 Dec, 2013 2 commits
  8. 07 Dec, 2013 4 commits
    • Magnus Hagander's avatar
      Fix a couple of typos · 54aa5ef7
      Magnus Hagander authored
      Noted by Peter Geoghegan
      54aa5ef7
    • Peter Eisentraut's avatar
      SSL: Support ECDH key exchange · 31647214
      Peter Eisentraut authored
      This sets up ECDH key exchange, when compiling against OpenSSL that
      supports EC.  Then the ECDHE-RSA and ECDHE-ECDSA cipher suites can be
      used for SSL connections.  The latter one means that EC keys are now
      usable.
      
      The reason for EC key exchange is that it's faster than DHE and it
      allows to go to higher security levels where RSA will be horribly slow.
      
      There is also new GUC option ssl_ecdh_curve that specifies the curve
      name used for ECDH.  It defaults to "prime256v1", which is the most
      common curve in use in HTTPS.
      
      From: Marko Kreen <markokr@gmail.com>
      Reviewed-by: default avatarAdrian Klaver <adrian.klaver@gmail.com>
      31647214
    • Fujii Masao's avatar
      Expose qurey ID in pg_stat_statements view. · 91484409
      Fujii Masao authored
      The query ID is the internal hash identifier of the statement,
      and was not available in pg_stat_statements view so far.
      
      Daniel Farina, Sameer Thakur and Peter Geoghegan, reviewed by me.
      91484409
    • Peter Eisentraut's avatar
      SSL: Add configuration option to prefer server cipher order · ef326752
      Peter Eisentraut authored
      By default, OpenSSL (and SSL/TLS in general) lets the client cipher
      order take priority.  This is OK for browsers where the ciphers were
      tuned, but few PostgreSQL client libraries make the cipher order
      configurable.  So it makes sense to have the cipher order in
      postgresql.conf take priority over client defaults.
      
      This patch adds the setting "ssl_prefer_server_ciphers" that can be
      turned on so that server cipher order is preferred.  Per discussion,
      this now defaults to on.
      
      From: Marko Kreen <markokr@gmail.com>
      Reviewed-by: default avatarAdrian Klaver <adrian.klaver@gmail.com>
      ef326752
  9. 06 Dec, 2013 1 commit