1. 07 Nov, 2014 5 commits
    • Alvaro Herrera's avatar
      Fix serial schedule · 0e892e04
      Alvaro Herrera authored
      Test misc depends on brin, but it was earlier in the serial schedule
      file.  I didn't notice this because I only run the parallel schedule,
      but the buildfarm exposed my folly ...
      0e892e04
    • Alvaro Herrera's avatar
      BRIN: Block Range Indexes · 7516f525
      Alvaro Herrera authored
      BRIN is a new index access method intended to accelerate scans of very
      large tables, without the maintenance overhead of btrees or other
      traditional indexes.  They work by maintaining "summary" data about
      block ranges.  Bitmap index scans work by reading each summary tuple and
      comparing them with the query quals; all pages in the range are returned
      in a lossy TID bitmap if the quals are consistent with the values in the
      summary tuple, otherwise not.  Normal index scans are not supported
      because these indexes do not store TIDs.
      
      As new tuples are added into the index, the summary information is
      updated (if the block range in which the tuple is added is already
      summarized) or not; in the latter case, a subsequent pass of VACUUM or
      the brin_summarize_new_values() function will create the summary
      information.
      
      For data types with natural 1-D sort orders, the summary info consists
      of the maximum and the minimum values of each indexed column within each
      page range.  This type of operator class we call "Minmax", and we
      supply a bunch of them for most data types with B-tree opclasses.
      Since the BRIN code is generalized, other approaches are possible for
      things such as arrays, geometric types, ranges, etc; even for things
      such as enum types we could do something different than minmax with
      better results.  In this commit I only include minmax.
      
      Catalog version bumped due to new builtin catalog entries.
      
      There's more that could be done here, but this is a good step forwards.
      
      Loosely based on ideas from Simon Riggs; code mostly by Álvaro Herrera,
      with contribution by Heikki Linnakangas.
      
      Patch reviewed by: Amit Kapila, Heikki Linnakangas, Robert Haas.
      Testing help from Jeff Janes, Erik Rijkers, Emanuel Calvo.
      
      PS:
        The research leading to these results has received funding from the
        European Union's Seventh Framework Programme (FP7/2007-2013) under
        grant agreement n° 318633.
      7516f525
    • Heikki Linnakangas's avatar
      Fix generation of SP-GiST vacuum WAL records. · 1961b1c1
      Heikki Linnakangas authored
      I broke these in 8776faa8. Backpatch to
      9.4, where that was done.
      1961b1c1
    • Heikki Linnakangas's avatar
      Remove obsolete cases from GiST update redo code. · 2effb72e
      Heikki Linnakangas authored
      The code that generated a record to clear the F_TUPLES_DELETED flag hasn't
      existed since we got rid of old-style VACUUM FULL. I kept the code that sets
      the flag, although it's not used for anything anymore, because it might
      still be interesting information for debugging purposes that some tuples
      have been deleted from a page.
      
      Likewise, the code to turn the root page from non-leaf to leaf page was
      removed when we got rid of old-style VACUUM FULL. Remove the code to replay
      that action, too.
      2effb72e
    • Tom Lane's avatar
      Cope with more than 64K phrases in a thesaurus dictionary. · d6e37b35
      Tom Lane authored
      dict_thesaurus stored phrase IDs in uint16 fields, so it would get confused
      and even crash if there were more than 64K entries in the configuration
      file.  It turns out to be basically free to widen the phrase IDs to uint32,
      so let's just do so.
      
      This was complained of some time ago by David Boutin (in bug #7793);
      he later submitted an informal patch but it was never acted on.
      We now have another complaint (bug #11901 from Luc Ouellette) so it's
      time to make something happen.
      
      This is basically Boutin's patch, but for future-proofing I also added a
      defense against too many words per phrase.  Note that we don't need any
      explicit defense against overflow of the uint32 counters, since before that
      happens we'd hit array allocation sizes that repalloc rejects.
      
      Back-patch to all supported branches because of the crash risk.
      d6e37b35
  2. 06 Nov, 2014 7 commits
    • Tom Lane's avatar
      Fix normalization of numeric values in JSONB GIN indexes. · 48759319
      Tom Lane authored
      The default JSONB GIN opclass (jsonb_ops) converts numeric data values
      to strings for storage in the index.  It must ensure that numeric values
      that would compare equal (such as 12 and 12.00) produce identical strings,
      else index searches would have behavior different from regular JSONB
      comparisons.  Unfortunately the function charged with doing this was
      completely wrong: it could reduce distinct numeric values to the same
      string, or reduce equivalent numeric values to different strings.  The
      former type of error would only lead to search inefficiency, but the
      latter type of error would cause index entries that should be found by
      a search to not be found.
      
      Repairing this bug therefore means that it will be necessary for 9.4 beta
      testers to reindex GIN jsonb_ops indexes, if they care about getting
      correct results from index searches involving numeric data values within
      the comparison JSONB object.
      
      Per report from Thomas Fanghaenel.
      48759319
    • Fujii Masao's avatar
      Prevent the unnecessary creation of .ready file for the timeline history file. · 5332b8ce
      Fujii Masao authored
      Previously .ready file was created for the timeline history file at the end
      of an archive recovery even when WAL archiving was not enabled.
      This creation is unnecessary and causes .ready file to remain infinitely.
      
      This commit changes an archive recovery so that it creates .ready file for
      the timeline history file only when WAL archiving is enabled.
      
      Backpatch to all supported versions.
      5332b8ce
    • Heikki Linnakangas's avatar
      Move the backup-block logic from XLogInsert to a new file, xloginsert.c. · 2076db2a
      Heikki Linnakangas authored
      xlog.c is huge, this makes it a little bit smaller, which is nice. Functions
      related to putting together the WAL record are in xloginsert.c, and the
      lower level stuff for managing WAL buffers and such are in xlog.c.
      
      Also move the definition of XLogRecord to a separate header file. This
      causes churn in the #includes of all the files that write WAL records, and
      redo routines, but it avoids pulling in xlog.h into most places.
      
      Reviewed by Michael Paquier, Alvaro Herrera, Andres Freund and Amit Kapila.
      2076db2a
    • Fujii Masao's avatar
      Fix typo in comment. · d2b8a2c7
      Fujii Masao authored
      Etsuro Fujita
      d2b8a2c7
    • Fujii Masao's avatar
      Implement IF NOT EXIST for CREATE INDEX. · 08309aaf
      Fujii Masao authored
      Fabrízio de Royes Mello, reviewed by Marti Raudsepp, Adam Brightwell and me.
      08309aaf
    • Bruce Momjian's avatar
    • Tom Lane's avatar
      Remove the last vestige of server-side autocommit. · 525a4899
      Tom Lane authored
      Long ago we briefly had an "autocommit" GUC that turned server-side
      autocommit on and off.  That behavior was removed in 7.4 after concluding
      that it broke far too much client-side logic, and making clients cope with
      both behaviors was impractical.  But the GUC variable was left behind, so
      as not to break any client code that might be trying to read its value.
      Enough time has now passed that we should remove the GUC completely.
      Whatever vestigial backwards-compatibility benefit it had is outweighed by
      the risk of confusion for newbies who assume it ought to do something,
      as per a recent complaint from Wolfgang Wilhelm.
      
      In passing, adjust what seemed to me a rather confusing documentation
      reference to libpq's autocommit behavior.  libpq as such knows nothing
      about autocommit, so psql is probably what was meant.
      525a4899
  3. 05 Nov, 2014 3 commits
    • Robert Haas's avatar
      Fix thinko in commit 2bd9e412. · c30be978
      Robert Haas authored
      Obviously, every translation unit should not be declaring this
      separately.  It needs to be PGDLLIMPORT as well, to avoid breaking
      third-party code that uses any of the functions that the commit
      mentioned above changed to macros.
      c30be978
    • Tom Lane's avatar
      Make CREATE TYPE print warnings if a datatype's I/O functions are volatile. · 465d7e18
      Tom Lane authored
      This is a followup to commit 43ac12c6,
      which added regression tests checking that I/O functions of built-in
      types are not marked volatile.  Complaining in CREATE TYPE should push
      developers of add-on types to fix any misdeclared functions in their
      types.  It's just a warning not an error, to avoid creating upgrade
      problems for what might be just cosmetic mis-markings.
      
      Aside from adding the warning code, fix a number of types that were
      sloppily created in the regression tests.
      465d7e18
    • Tom Lane's avatar
      Fix volatility markings of some contrib I/O functions. · 66c029c8
      Tom Lane authored
      In general, datatype I/O functions are supposed to be immutable or at
      worst stable.  Some contrib I/O functions were, through oversight, not
      marked with any volatility property at all, which made them VOLATILE.
      Since (most of) these functions actually behave immutably, the erroneous
      marking isn't terribly harmful; but it can be user-visible in certain
      circumstances, as per a recent bug report from Joe Van Dyk in which a
      cast to text was disallowed in an expression index definition.
      
      To fix, just adjust the declarations in the extension SQL scripts.  If we
      were being very fussy about this, we'd bump the extension version numbers,
      but that seems like more trouble (for both developers and users) than the
      problem is worth.
      
      A fly in the ointment is that chkpass_in actually is volatile, because
      of its use of random() to generate a fresh salt when presented with a
      not-yet-encrypted password.  This is bad because of the general assumption
      that I/O functions aren't volatile: the consequence is that records or
      arrays containing chkpass elements may have input behavior a bit different
      from a bare chkpass column.  But there seems no way to fix this without
      breaking existing usage patterns for chkpass, and the consequences of the
      inconsistency don't seem bad enough to justify that.  So for the moment,
      just document it in a comment.
      
      Since we're not bumping version numbers, there seems no harm in
      back-patching these fixes; at least future installations will get the
      functions marked correctly.
      66c029c8
  4. 04 Nov, 2014 4 commits
    • Peter Eisentraut's avatar
      doc: Move misplaced paragraph · e809fa2c
      Peter Eisentraut authored
      e809fa2c
    • Tom Lane's avatar
      Drop no-longer-needed buffers during ALTER DATABASE SET TABLESPACE. · 33f80f84
      Tom Lane authored
      The previous coding assumed that we could just let buffers for the
      database's old tablespace age out of the buffer arena naturally.
      The folly of that is exposed by bug #11867 from Marc Munro: the user could
      later move the database back to its original tablespace, after which any
      still-surviving buffers would match lookups again and appear to contain
      valid data.  But they'd be missing any changes applied while the database
      was in the new tablespace.
      
      This has been broken since ALTER SET TABLESPACE was introduced, so
      back-patch to all supported branches.
      33f80f84
    • Heikki Linnakangas's avatar
      Switch to CRC-32C in WAL and other places. · 5028f22f
      Heikki Linnakangas authored
      The old algorithm was found to not be the usual CRC-32 algorithm, used by
      Ethernet et al. We were using a non-reflected lookup table with code meant
      for a reflected lookup table. That's a strange combination that AFAICS does
      not correspond to any bit-wise CRC calculation, which makes it difficult to
      reason about its properties. Although it has worked well in practice, seems
      safer to use a well-known algorithm.
      
      Since we're changing the algorithm anyway, we might as well choose a
      different polynomial. The Castagnoli polynomial has better error-correcting
      properties than the traditional CRC-32 polynomial, even if we had
      implemented it correctly. Another reason for picking that is that some new
      CPUs have hardware support for calculating CRC-32C, but not CRC-32, let
      alone our strange variant of it. This patch doesn't add any support for such
      hardware, but a future patch could now do that.
      
      The old algorithm is kept around for tsquery and pg_trgm, which use the
      values in indexes that need to remain compatible so that pg_upgrade works.
      While we're at it, share the old lookup table for CRC-32 calculation
      between hstore, ltree and core. They all use the same table, so might as
      well.
      5028f22f
    • Heikki Linnakangas's avatar
      Remove support for 64-bit CRC. · 404bc51c
      Heikki Linnakangas authored
      It hasn't been used for anything for a long time.
      404bc51c
  5. 03 Nov, 2014 8 commits
  6. 02 Nov, 2014 1 commit
  7. 01 Nov, 2014 1 commit
  8. 31 Oct, 2014 4 commits
  9. 30 Oct, 2014 3 commits
    • Robert Haas's avatar
      Extend dsm API with a new function dsm_unpin_mapping. · f7102b04
      Robert Haas authored
      This reassociates a dynamic shared memory handle previous passed to
      dsm_pin_mapping with the current resource owner, so that it will be
      cleaned up at the end of the current query.
      
      Patch by me.  Review of the function name by Andres Freund, Amit
      Kapila, Jim Nasby, Petr Jelinek, and Álvaro Herrera.
      f7102b04
    • Tom Lane's avatar
      Test IsInTransactionChain, not IsTransactionBlock, in vac_update_relstats. · fd0f651a
      Tom Lane authored
      As noted by Noah Misch, my initial cut at fixing bug #11638 didn't cover
      all cases where ANALYZE might be invoked in an unsafe context.  We need to
      test the result of IsInTransactionChain not IsTransactionBlock; which is
      notationally a pain because IsInTransactionChain requires an isTopLevel
      flag, which would have to be passed down through several levels of callers.
      I chose to pass in_outer_xact (ie, the result of IsInTransactionChain)
      rather than isTopLevel per se, as that seemed marginally more apropos
      for the intermediate functions to know about.
      fd0f651a
    • Robert Haas's avatar
      "Pin", rather than "keep", dynamic shared memory mappings and segments. · 6057c212
      Robert Haas authored
      Nobody seemed concerned about this naming when it originally went in,
      but there's a pending patch that implements the opposite of
      dsm_keep_mapping, and the term "unkeep" was judged unpalatable.
      "unpin" has existing precedent in the PostgreSQL code base, and the
      English language, so use this terminology instead.
      
      Per discussion, back-patch to 9.4.
      6057c212
  10. 29 Oct, 2014 4 commits
    • Peter Eisentraut's avatar
      Remove use of TAP subtests · 7912f9b7
      Peter Eisentraut authored
      They turned out to be too much of a portability headache, because they
      need a fairly new version of Test::More to work properly.
      7912f9b7
    • Tom Lane's avatar
      Avoid corrupting tables when ANALYZE inside a transaction is rolled back. · e0722d9c
      Tom Lane authored
      VACUUM and ANALYZE update the target table's pg_class row in-place, that is
      nontransactionally.  This is OK, more or less, for the statistical columns,
      which are mostly nontransactional anyhow.  It's not so OK for the DDL hint
      flags (relhasindex etc), which might get changed in response to
      transactional changes that could still be rolled back.  This isn't a
      problem for VACUUM, since it can't be run inside a transaction block nor
      in parallel with DDL on the table.  However, we allow ANALYZE inside a
      transaction block, so if the transaction had earlier removed the last
      index, rule, or trigger from the table, and then we roll back the
      transaction after ANALYZE, the table would be left in a corrupted state
      with the hint flags not set though they should be.
      
      To fix, suppress the hint-flag updates if we are InTransactionBlock().
      This is safe enough because it's always OK to postpone hint maintenance
      some more; the worst-case consequence is a few extra searches of pg_index
      et al.  There was discussion of instead using a transactional update,
      but that would change the behavior in ways that are not all desirable:
      in most scenarios we're better off keeping ANALYZE's statistical values
      even if the ANALYZE itself rolls back.  In any case we probably don't want
      to change this behavior in back branches.
      
      Per bug #11638 from Casey Shobe.  This has been broken for a good long
      time, so back-patch to all supported branches.
      
      Tom Lane and Michael Paquier, initial diagnosis by Andres Freund
      e0722d9c
    • Robert Haas's avatar
      Avoid setup work for invalidation messages at start-of-(sub)xact. · 6cb4afff
      Robert Haas authored
      Instead of initializing a new TransInvalidationInfo for every
      transaction or subtransaction, we can just do it for those
      transactions or subtransactions that actually need to queue
      invalidation messages.  That also avoids needing to free those
      entries at the end of a transaction or subtransaction that does
      not generate any invalidation messages, which is by far the
      common case.
      
      Patch by me.  Review by Simon Riggs and Andres Freund.
      6cb4afff
    • Heikki Linnakangas's avatar
      Reset error message at PQreset() · 8f8314b5
      Heikki Linnakangas authored
      If you call PQreset() repeatedly, and the connection cannot be
      re-established, the error messages from the failed connection attempts
      kept accumulating in the error string.
      
      Fixes bug #11455 reported by Caleb Epstein. Backpatch to all supported
      versions.
      8f8314b5