1. 30 Mar, 2019 7 commits
    • Tom Lane's avatar
      Speed up planning when partitions can be pruned at plan time. · 428b260f
      Tom Lane authored
      Previously, the planner created RangeTblEntry and RelOptInfo structs
      for every partition of a partitioned table, even though many of them
      might later be deemed uninteresting thanks to partition pruning logic.
      This incurred significant overhead when there are many partitions.
      Arrange to postpone creation of these data structures until after
      we've processed the query enough to identify restriction quals for
      the partitioned table, and then apply partition pruning before not
      after creation of each partition's data structures.  In this way
      we need not open the partition relations at all for partitions that
      the planner has no real interest in.
      
      For queries that can be proven at plan time to access only a small
      number of partitions, this patch improves the practical maximum
      number of partitions from under 100 to perhaps a few thousand.
      
      Amit Langote, reviewed at various times by Dilip Kumar, Jesper Pedersen,
      Yoshikazu Imai, and David Rowley
      
      Discussion: https://postgr.es/m/9d7c5112-cb99-6a47-d3be-cf1ee6862a1d@lab.ntt.co.jp
      428b260f
    • Tomas Vondra's avatar
      Fix compiler warnings in multivariate MCV code · ad3107b9
      Tomas Vondra authored
      Compiler warnings were observed on gcc 3.4.6 (on gaur).
      
      The assert is unnecessary, as the indexes are uint16 and so always >= 0.
      
      Reported-by: Tom Lane
      ad3107b9
    • Tomas Vondra's avatar
      Additional fixes of memory alignment in pg_mcv_list code · ea4e1c0e
      Tomas Vondra authored
      Commit d85e0f36 tried to fix memory alignment issues in serialization
      and deserialization of pg_mcv_list values, but it was a few bricks shy.
      The arrays of uint16 indexes in serialized items was not aligned, and
      the both the values and isnull flags were using the same pointer.
      
      Per investigation by Tom Lane on gaur.
      ea4e1c0e
    • Tom Lane's avatar
      Avoid crash in partitionwise join planning under GEQO. · 7ad6498f
      Tom Lane authored
      While trying to plan a partitionwise join, we may be faced with cases
      where one or both input partitions for a particular segment of the join
      have been pruned away.  In HEAD and v11, this is problematic because
      earlier processing didn't bother to make a pruned RelOptInfo fully
      valid.  With an upcoming patch to make partition pruning more efficient,
      this'll be even more problematic because said RelOptInfo won't exist at
      all.
      
      The existing code attempts to deal with this by retroactively making the
      RelOptInfo fully valid, but that causes crashes under GEQO because join
      planning is done in a short-lived memory context.  In v11 we could
      probably have fixed this by switching to the planner's main context
      while fixing up the RelOptInfo, but that idea doesn't scale well to the
      upcoming patch.  It would be better not to mess with the base-relation
      data structures during join planning, anyway --- that's just a recipe
      for order-of-operations bugs.
      
      In many cases, though, we don't actually need the child RelOptInfo,
      because if the input is certainly empty then the join segment's result
      is certainly empty, so we can skip making a join plan altogether.  (The
      existing code ultimately arrives at the same conclusion, but only after
      doing a lot more work.)  This approach works except when the pruned-away
      partition is on the nullable side of a LEFT, ANTI, or FULL join, and the
      other side isn't pruned.  But in those cases the existing code leaves a
      lot to be desired anyway --- the correct output is just the result of
      the unpruned side of the join, but we were emitting a useless outer join
      against a dummy Result.  Pending somebody writing code to handle that
      more nicely, let's just abandon the partitionwise-join optimization in
      such cases.
      
      When the modified code skips making a join plan, it doesn't make a
      join RelOptInfo either; this requires some upper-level code to
      cope with nulls in part_rels[] arrays.  We would have had to have
      that anyway after the upcoming patch.
      
      Back-patch to v11 since the crash is demonstrable there.
      
      Discussion: https://postgr.es/m/8305.1553884377@sss.pgh.pa.us
      7ad6498f
    • Peter Eisentraut's avatar
      doc: Fix typo · ef6576f5
      Peter Eisentraut authored
      Author: Justin Pryzby <pryzby@telsasoft.com>
      ef6576f5
    • Peter Eisentraut's avatar
      Generated columns · fc22b662
      Peter Eisentraut authored
      This is an SQL-standard feature that allows creating columns that are
      computed from expressions rather than assigned, similar to a view or
      materialized view but on a column basis.
      
      This implements one kind of generated column: stored (computed on
      write).  Another kind, virtual (computed on read), is planned for the
      future, and some room is left for it.
      Reviewed-by: default avatarMichael Paquier <michael@paquier.xyz>
      Reviewed-by: default avatarPavel Stehule <pavel.stehule@gmail.com>
      Discussion: https://www.postgresql.org/message-id/flat/b151f851-4019-bdb1-699e-ebab07d2f40a@2ndquadrant.com
      fc22b662
    • Peter Eisentraut's avatar
      Small code simplification for REINDEX CONCURRENTLY · 6b8b5364
      Peter Eisentraut authored
      This was left over from an earlier code structure.
      6b8b5364
  2. 29 Mar, 2019 13 commits
  3. 28 Mar, 2019 7 commits
    • Thomas Munro's avatar
      Fix typo. · 7e69323b
      Thomas Munro authored
      Author: Masahiko Sawada
      7e69323b
    • Andres Freund's avatar
      Fix a few comment copy & pastos. · 46bcd2af
      Andres Freund authored
      46bcd2af
    • Tomas Vondra's avatar
      Fix deserialization of pg_mcv_list values · 62bf0fb3
      Tomas Vondra authored
      There were multiple issues in deserialization of pg_mcv_list values.
      
      Firstly, the data is loaded from syscache, but the deserialization was
      performed after ReleaseSysCache(), at which point the data might have
      already disappeared.  Fixed by moving the calls in statext_mcv_load,
      and using the same NULL-handling code as existing stats.
      
      Secondly, the deserialized representation used pointers into the
      serialized representation.  But that is also unsafe, because the data
      may disappear at any time.  Fixed by reworking and simplifying the
      deserialization code to always copy all the data.
      
      And thirdly, when deserializing values for types passed by value, the
      code simply did memcpy(d,s,typlen) which however does not work on
      bigendian machines.  Fixed by using fetch_att/store_att_byval.
      62bf0fb3
    • Peter Eisentraut's avatar
      doc: Fix typo · f3afbbda
      Peter Eisentraut authored
      f3afbbda
    • Thomas Munro's avatar
      Use FullTransactionId for the transaction stack. · ad308058
      Thomas Munro authored
      Provide GetTopFullTransactionId() and GetCurrentFullTransactionId().
      The intended users of these interfaces are access methods that use
      xids for visibility checks but don't want to have to go back and
      "freeze" existing references some time later before the 32 bit xid
      counter wraps around.
      
      Use a new struct to serialize the transaction state for parallel
      query, because FullTransactionId doesn't fit into the previous
      serialization scheme very well.
      
      Author: Thomas Munro
      Reviewed-by: Heikki Linnakangas
      Discussion: https://postgr.es/m/CAA4eK1%2BMv%2Bmb0HFfWM9Srtc6MVe160WFurXV68iAFMcagRZ0dQ%40mail.gmail.com
      ad308058
    • Thomas Munro's avatar
      Add basic infrastructure for 64 bit transaction IDs. · 2fc7af5e
      Thomas Munro authored
      Instead of inferring epoch progress from xids and checkpoints,
      introduce a 64 bit FullTransactionId type and use it to track xid
      generation.  This fixes an unlikely bug where the epoch is reported
      incorrectly if the range of active xids wraps around more than once
      between checkpoints.
      
      The only user-visible effect of this commit is to correct the epoch
      used by txid_current() and txid_status(), also visible with
      pg_controldata, in those rare circumstances.  It also creates some
      basic infrastructure so that later patches can use 64 bit
      transaction IDs in more places.
      
      The new type is a struct that we pass by value, as a form of strong
      typedef.  This prevents the sort of accidental confusion between
      TransactionId and FullTransactionId that would be possible if we
      were to use a plain old uint64.
      
      Author: Thomas Munro
      Reported-by: Amit Kapila
      Reviewed-by: Andres Freund, Tom Lane, Heikki Linnakangas
      Discussion: https://postgr.es/m/CAA4eK1%2BMv%2Bmb0HFfWM9Srtc6MVe160WFurXV68iAFMcagRZ0dQ%40mail.gmail.com
      2fc7af5e
    • Andres Freund's avatar
      tableam: Support for an index build's initial table scan(s). · 2a96909a
      Andres Freund authored
      To support building indexes over tables of different AMs, the scans to
      do so need to be routed through the table AM.  While moving a fair
      amount of code, nearly all the changes are just moving code to below a
      callback.
      
      Currently the range based interface wouldn't make much sense for non
      block based table AMs. But that seems aceptable for now.
      
      Author: Andres Freund
      Discussion: https://postgr.es/m/20180703070645.wchpu5muyto5n647@alap3.anarazel.de
      2a96909a
  4. 27 Mar, 2019 13 commits
    • Peter Eisentraut's avatar
      Fix vpath build · 12bb35fc
      Peter Eisentraut authored
      Skip doc/src/sgml/images/Makefile since the directory is not created.
      12bb35fc
    • Peter Eisentraut's avatar
      doc: Add some images · ea55aec0
      Peter Eisentraut authored
      Add infrastructure for having images in the documentation, in SVG
      format.  Add two images to start with.  See the included README file
      for instructions.
      
      Author: Jürgen Purtz <juergen@purtz.de>
      Author: Peter Eisentraut <peter.eisentraut@2ndquadrant.com>
      Discussion: https://www.postgresql.org/message-id/flat/aaa54502-05c0-4ea5-9af8-770411a6bf4b@purtz.de
      ea55aec0
    • Peter Eisentraut's avatar
      doc: Move htmlhelp output to subdirectory · 477422c9
      Peter Eisentraut authored
      This makes it behave more like the html output.  That will make some
      subsequent changes across all output formats easier.
      477422c9
    • Peter Eisentraut's avatar
      Use Pandoc also for plain-text documentation output · 2488ea7a
      Peter Eisentraut authored
      The makefile rule for the (rarely used) plain-text output postgres.txt
      was still written to use lynx, but in
      96b8b8b6, where the INSTALL file was
      switched to pandoc, the rest of the makefile support for lynx was
      removed, so this was broken.  Rewrite the rule to also use pandoc for
      postgres.txt.
      2488ea7a
    • Tomas Vondra's avatar
      Minor improvements for the multivariate MCV lists · a63b29a1
      Tomas Vondra authored
      The MCV build should always call get_mincount_for_mcv_list(), as the
      there is no other logic to decide whether the MCV list represents all
      the data. So just remove the (ngroups > nitems) condition.
      
      Also, when building MCV lists, the number of items was limited by the
      statistics target (i.e. up to 10000). But when deserializing the MCV
      list, a different value (8192) was used to check the input, causing
      an error.  Simply ensure that the same value is used in both places.
      
      This should have been included in 7300a699, but I forgot to include it
      in that commit.
      a63b29a1
    • Tomas Vondra's avatar
      Add support for multivariate MCV lists · 7300a699
      Tomas Vondra authored
      Introduce a third extended statistic type, supported by the CREATE
      STATISTICS command - MCV lists, a generalization of the statistic
      already built and used for individual columns.
      
      Compared to the already supported types (n-distinct coefficients and
      functional dependencies), MCV lists are more complex, include column
      values and allow estimation of much wider range of common clauses
      (equality and inequality conditions, IS NULL, IS NOT NULL etc.).
      Similarly to the other types, a new pseudo-type (pg_mcv_list) is used.
      
      Author: Tomas Vondra
      Reviewed-by: Dean Rasheed, David Rowley, Mark Dilger, Alvaro Herrera
      Discussion: https://postgr.es/m/dfdac334-9cf2-2597-fb27-f0fb3753f435@2ndquadrant.com
      7300a699
    • Tom Lane's avatar
      Avoid passing query tlist around separately from root->processed_tlist. · 333ed246
      Tom Lane authored
      In the dim past, the planner kept the fully-processed version of the query
      targetlist (the result of preprocess_targetlist) in grouping_planner's
      local variable "tlist", and only grudgingly passed it to individual other
      routines as needed.  Later we discovered a need to still have it available
      after grouping_planner finishes, and invented the root->processed_tlist
      field for that purpose, but it wasn't used internally to grouping_planner;
      the tlist was still being passed around separately in the same places as
      before.
      
      Now comes a proposed patch to allow appendrel expansion to add entries
      to the processed tlist, well after preprocess_targetlist has finished
      its work.  To avoid having to pass around the tlist explicitly, it's
      proposed to allow appendrel expansion to modify root->processed_tlist.
      That makes aliasing the tlist with assorted parameters and local
      variables really scary.  It would accidentally work as long as the
      tlist is initially nonempty, because then the List header won't move
      around, but it's not exactly hard to think of ways for that to break.
      Aliased values are poor programming practice anyway.
      
      Hence, get rid of local variables and parameters that can be identified
      with root->processed_tlist, in favor of just using that field directly.
      And adjust comments to match.  (Some of the new comments speak as though
      it's already possible for appendrel expansion to modify the tlist; that's
      not true yet, but will happen in a later patch.)
      
      Discussion: https://postgr.es/m/9d7c5112-cb99-6a47-d3be-cf1ee6862a1d@lab.ntt.co.jp
      333ed246
    • Alvaro Herrera's avatar
      pgbench: doExecuteCommand -> executeMetaCommand · 9938d116
      Alvaro Herrera authored
      The new function is only in charge of meta commands, not SQL commands.
      This change makes the code a little clearer: now all the state changes
      are effected by advanceConnectionState.  It also removes one indent
      level, which makes the diff look bulkier than it really is.
      
      Author: Fabien Coelho
      Reviewed-by: Kirk Jamison
      Discussion: https://postgr.es/m/alpine.DEB.2.21.1811240904500.12627@lancre
      9938d116
    • Tom Lane's avatar
      Suppress uninitialized-variable warning. · a51cc7e9
      Tom Lane authored
      Apparently Andres' compiler is smart enough to see that hpage
      must be initialized before use ... but mine isn't.
      a51cc7e9
    • Michael Paquier's avatar
      Improve error handling of column references in expression transformation · ecfed4a1
      Michael Paquier authored
      Column references are not allowed in default expressions and partition
      bound expressions, and are restricted as such once the transformation of
      their expressions is done.  However, trying to use more complex column
      references can lead to confusing error messages.  For example, trying to
      use a two-field column reference name for default expressions and
      partition bounds leads to "missing FROM-clause entry for table", which
      makes no sense in their respective context.
      
      In order to make the errors generated more useful, this commit adds more
      verbose messages when transforming column references depending on the
      context.  This has a little consequence though: for example an
      expression using an aggregate with a column reference as argument would
      cause an error to be generated for the column reference, while the
      aggregate was the problem reported before this commit because column
      references get transformed first.
      
      The confusion exists for default expressions for a long time, and the
      problem is new as of v12 for partition bounds.  Still per the lack of
      complaints on the matter no backpatch is done.
      
      The patch has been written by Amit Langote and me, and Tom Lane has
      provided the improvement of the documentation for default expressions on
      the CREATE TABLE page.
      
      Author: Amit Langote, Michael Paquier
      Reviewed-by: Tom Lane
      Discussion: https://postgr.es/m/20190326020853.GM2558@paquier.xyz
      ecfed4a1
    • Thomas Munro's avatar
      Fix off-by-one error in txid_status(). · d2fd7f74
      Thomas Munro authored
      The transaction ID returned by GetNextXidAndEpoch() is in the future,
      so we can't attempt to access its status or we might try to read a
      CLOG page that doesn't exist.  The > vs >= confusion probably stemmed
      from the choice of a variable name containing the word "last" instead
      of "next", so fix that too.
      
      Back-patch to 10 where the function arrived.
      
      Author: Thomas Munro
      Discussion: https://postgr.es/m/CA%2BhUKG%2Buua_BV5cyfsioKVN2d61Lukg28ECsWTXKvh%3DBtN2DPA%40mail.gmail.com
      d2fd7f74
    • Michael Paquier's avatar
      Switch some palloc/memset calls to palloc0 · 1983af8e
      Michael Paquier authored
      Some code paths have been doing some allocations followed by an
      immediate memset() to initialize the allocated area with zeros, this is
      a bit overkill as there are already interfaces to do both things in one
      call.
      
      Author: Daniel Gustafsson
      Reviewed-by: Michael Paquier
      Discussion: https://postgr.es/m/vN0OodBPkKs7g2Z1uyk3CUEmhdtspHgYCImhlmSxv1Xn6nY1ZnaaGHL8EWUIQ-NEv36tyc4G5-uA3UXUF2l4sFXtK_EQgLN1hcgunlFVKhA=@yesql.se
      1983af8e
    • Michael Paquier's avatar
      Switch function current_schema[s]() to be parallel-unsafe · 5bde1651
      Michael Paquier authored
      When invoked for the first time in a session, current_schema() and
      current_schemas() can finish by creating a temporary schema.  Currently
      those functions are parallel-safe, however if for a reason or another
      they get launched across multiple parallel workers, they would fail when
      attempting to create a temporary schema as temporary contexts are not
      supported in this case.
      
      The original issue has been spotted by buildfarm members crake and
      lapwing, after commit c5660e0a has introduced the first regression tests
      based on current_schema() in the tree.  After that, 396676b0 has
      introduced a workaround to avoid parallel plans but that was not
      completely right either.
      
      Catversion is bumped.
      
      Author: Michael Paquier
      Reviewed-by: Daniel Gustafsson
      Discussion: https://postgr.es/m/20190118024618.GF1883@paquier.xyz
      5bde1651