1. 21 May, 2022 2 commits
    • Tom Lane's avatar
      Show 'AS "?column?"' explicitly when it's important. · 6f7eec11
      Tom Lane authored
      ruleutils.c was coded to suppress the AS label for a SELECT output
      expression if the column name is "?column?", which is the parser's
      fallback if it can't think of something better.  This is fine, and
      avoids ugly clutter, so long as (1) nothing further up in the parse
      tree relies on that column name or (2) the same fallback would be
      assigned when the rule or view definition is reloaded.  Unfortunately
      (2) is far from certain, both because ruleutils.c might print the
      expression in a different form from how it was originally written
      and because FigureColname's rules might change in future releases.
      So we shouldn't rely on that.
      
      Detecting exactly whether there is any outer-level use of a SELECT
      column name would be rather expensive.  This patch takes the simpler
      approach of just passing down a flag indicating whether there *could*
      be any outer use; for example, the output column names of a SubLink
      are not referenceable, and we also do not care about the names exposed
      by the right-hand side of a setop.  This is sufficient to suppress
      unwanted clutter in all but one case in the regression tests.  That
      seems like reasonable evidence that it won't be too much in users'
      faces, while still fixing the cases we need to fix.
      
      Per bug #17486 from Nicolas Lutic.  This issue is ancient, so
      back-patch to all supported branches.
      
      Discussion: https://postgr.es/m/17486-1ad6fd786728b8af@postgresql.org
      6f7eec11
    • Michael Paquier's avatar
      doc: Mention pg_read_all_stats in description of track_activities · 7f798e89
      Michael Paquier authored
      The description of track_activities mentioned that it is visible to
      superusers and that the information related to the current session can
      be seen, without telling about pg_read_all_stats.  Roles that are
      granted the privileges of pg_read_all_stats can also see this
      information, so mention it in the docs.
      
      Author: Ian Barwick
      Reviewed-by: Nathan Bossart
      Discussion: https://postgr.es/m/CAB8KJ=jhPyYFu-A5r-ZGP+Ax715mUKsMxAGcEQ9Cx_mBAmrPow@mail.gmail.com
      Backpatch-through: 10
      7f798e89
  2. 20 May, 2022 2 commits
  3. 19 May, 2022 3 commits
  4. 18 May, 2022 2 commits
  5. 16 May, 2022 2 commits
    • David Rowley's avatar
      Fix incorrect row estimates used for Memoize costing · 23c2b76a
      David Rowley authored
      In order to estimate the cache hit ratio of a Memoize node, one of the
      inputs we require is the estimated number of times the Memoize node will
      be rescanned.  The higher this number, the large the cache hit ratio is
      likely to become.  Unfortunately, the value being passed as the number of
      "calls" to the Memoize was incorrectly using the Nested Loop's
      outer_path->parent->rows instead of outer_path->rows.  This failed to
      account for the fact that the outer_path might be parameterized by some
      upper-level Nested Loop.
      
      This problem could lead to Memoize plans appearing more favorable than
      they might actually be.  It could also lead to extended executor startup
      times when work_mem values were large due to the planner setting overly
      large MemoizePath->est_entries resulting in the Memoize hash table being
      initially made much larger than might be required.
      
      Fix this simply by passing outer_path->rows rather than
      outer_path->parent->rows.  Also, adjust the expected regression test
      output for a plan change.
      
      Reported-by: Pavel Stehule
      Author: David Rowley
      Discussion: https://postgr.es/m/CAFj8pRAMp%3DQsMi6sPQJ4W3hczoFJRvyXHJV3AZAZaMyTVM312Q%40mail.gmail.com
      Backpatch-through: 14, where Memoize was introduced
      23c2b76a
    • Michael Paquier's avatar
      Fix control file update done in restartpoints still running after promotion · 6dced63b
      Michael Paquier authored
      If a cluster is promoted (aka the control file shows a state different
      than DB_IN_ARCHIVE_RECOVERY) while CreateRestartPoint() is still
      processing, this function could miss an update of the control file for
      "checkPoint" and "checkPointCopy" but still do the recycling and/or
      removal of the past WAL segments, assuming that the to-be-updated LSN
      values should be used as reference points for the cleanup.  This causes
      a follow-up restart attempting crash recovery to fail with a PANIC on a
      missing checkpoint record if the end-of-recovery checkpoint triggered by
      the promotion did not complete while the cluster abruptly stopped or
      crashed before the completion of this checkpoint.  The PANIC would be
      caused by the redo LSN referred in the control file as located in a
      segment already gone, recycled by the previous restartpoint with
      "checkPoint" out-of-sync in the control file.
      
      This commit fixes the update of the control file during restartpoints so
      as "checkPoint" and "checkPointCopy" are updated even if the cluster has
      been promoted while a restartpoint is running, to be on par with the set
      of WAL segments actually recycled in the end of CreateRestartPoint().
      
      7863ee4 has fixed this problem already on master, but the release timing
      of the latest point versions did not let me enough time to study and fix
      that on all the stable branches.
      
      Reported-by: Fujii Masao, Rui Zhao
      Author: Kyotaro Horiguchi
      Reviewed-by: Nathan Bossart, Michael Paquier
      Discussion: https://postgr.es/m/20220316.102444.2193181487576617583.horikyota.ntt@gmail.com
      Backpatch-through: 10
      6dced63b
  6. 12 May, 2022 1 commit
    • Tom Lane's avatar
      Make pull_var_clause() handle GroupingFuncs exactly like Aggrefs. · ac51c9fb
      Tom Lane authored
      This follows in the footsteps of commit 2591ee8ec by removing one more
      ill-advised shortcut from planning of GroupingFuncs.  It's true that
      we don't intend to execute the argument expression(s) at runtime, but
      we still have to process any Vars appearing within them, or we risk
      failure at setrefs.c time (or more fundamentally, in EXPLAIN trying
      to print such an expression).  Vars in upper plan nodes have to have
      referents in the next plan level, whether we ever execute 'em or not.
      
      Per bug #17479 from Michael J. Sullivan.  Back-patch to all supported
      branches.
      
      Richard Guo
      
      Discussion: https://postgr.es/m/17479-6260deceaf0ad304@postgresql.org
      ac51c9fb
  7. 11 May, 2022 2 commits
    • Amit Kapila's avatar
      Fix the logical replication timeout during large transactions. · d6da71fa
      Amit Kapila authored
      The problem is that we don't send keep-alive messages for a long time
      while processing large transactions during logical replication where we
      don't send any data of such transactions. This can happen when the table
      modified in the transaction is not published or because all the changes
      got filtered. We do try to send the keep_alive if necessary at the end of
      the transaction (via WalSndWriteData()) but by that time the
      subscriber-side can timeout and exit.
      
      To fix this we try to send the keepalive message if required after
      processing certain threshold of changes.
      
      Reported-by: Fabrice Chapuis
      Author: Wang wei and Amit Kapila
      Reviewed By: Masahiko Sawada, Euler Taveira, Hou Zhijie, Hayato Kuroda
      Backpatch-through: 10
      Discussion: https://postgr.es/m/CAA5-nLARN7-3SLU_QUxfy510pmrYK6JJb=bk3hcgemAM_pAv+w@mail.gmail.com
      d6da71fa
    • Michael Paquier's avatar
      Improve setup of environment values for commands in MSVC's vcregress.pl · ca9e9b08
      Michael Paquier authored
      The current setup assumes that commands for lz4, zstd and gzip always
      exist by default if not enforced by a user's environment.  However,
      vcpkg, as one example, installs libraries but no binaries, so this
      default setup to assume that a command should always be present would
      cause failures.  This commit improves the detection of such external
      commands as follows:
      * If a ENV value is available, trust the environment/user and use it.
      * If a ENV value is not available, check its execution by looking in the
      current PATH, by launching a simple "$command --version" (that should be
      portable enough).
      ** On execution failure, ignore ENV{command}.
      ** On execution success, set ENV{command} = "$command".
      
      Note that this new rule applies to gzip, lz4 and zstd but not tar that
      we assume will always exist.  Those commands are set up in the
      environment only when using bincheck and taptest.  The CI includes all
      those commands and I have checked that their setup is correct there.  I
      have also tested this change in a MSVC environment where we have none of
      those commands.
      
      While on it, remove the references to lz4 from the documentation and
      vcregress.pl in ~v13.  --with-lz4 has been added in v14~ so there is no
      point to have this information in these older branches.
      
      Reported-by: Andrew Dunstan
      Reviewed-by: Andrew Dunstan
      Discussion: https://postgr.es/m/14402151-376b-a57a-6d0c-10ad12608e12@dunslane.net
      Backpatch-through: 10
      ca9e9b08
  8. 10 May, 2022 1 commit
    • Tom Lane's avatar
      configure: don't probe for libldap_r if libldap is 2.5 or newer. · 12736e7d
      Tom Lane authored
      In OpenLDAP 2.5 and later, libldap itself is always thread-safe and
      there's never a libldap_r.  Our existing coding dealt with that
      by assuming it wouldn't find libldap_r if libldap is thread-safe.
      But that rule fails to cope if there are multiple OpenLDAP versions
      visible, as is likely to be the case on macOS in particular.  We'd
      end up using shiny new libldap in the backend and a hoary libldap_r
      in libpq.
      
      Instead, once we've found libldap, check if it's >= 2.5 (by
      probing for a function introduced then) and don't bother looking
      for libldap_r if so.  While one can imagine library setups that
      this'd still give the wrong answer for, they seem unlikely to
      occur in practice.
      
      Per report from Peter Eisentraut.  Back-patch to all supported branches.
      
      Discussion: https://postgr.es/m/fedacd7c-2a38-25c9-e7ff-dea549d0e979@enterprisedb.com
      12736e7d
  9. 09 May, 2022 8 commits
  10. 08 May, 2022 1 commit
  11. 07 May, 2022 2 commits
  12. 06 May, 2022 2 commits
  13. 05 May, 2022 2 commits
  14. 04 May, 2022 2 commits
  15. 03 May, 2022 3 commits
  16. 02 May, 2022 1 commit
  17. 28 Apr, 2022 1 commit
    • Etsuro Fujita's avatar
      Disable asynchronous execution if using gating Result nodes. · ebb79024
      Etsuro Fujita authored
      mark_async_capable_plan(), which is called from create_append_plan() to
      determine whether subplans are async-capable, failed to take into
      account that the given subplan created from a given subpath might
      include a gating Result node if the subpath is a SubqueryScanPath or
      ForeignPath, causing a segmentation fault there when the subplan created
      from a SubqueryScanPath includes the Result node, or causing
      ExecAsyncRequest() to throw an error about an unrecognized node type
      when the subplan created from a ForeignPath includes the Result node,
      because in the latter case the Result node was unintentionally
      considered as async-capable, but we don't currently support executing
      Result nodes asynchronously.  Fix by modifying mark_async_capable_plan()
      to disable asynchronous execution in such cases.  Also, adjust code in
      the ProjectionPath case in mark_async_capable_plan(), for consistency
      with other cases, and adjust/improve comments there.
      
      is_async_capable_path() added in commit 27e1f145, which was rewritten
      to mark_async_capable_plan() in a later commit, has the same issue,
      causing the error at execution mentioned above, so back-patch to v14
      where the aforesaid commit went in.
      
      Per report from Justin Pryzby.
      
      Etsuro Fujita, reviewed by Zhihong Yu and Justin Pryzby.
      
      Discussion: https://postgr.es/m/20220408124338.GK24419%40telsasoft.com
      ebb79024
  18. 25 Apr, 2022 2 commits
  19. 23 Apr, 2022 1 commit