1. 07 Feb, 2021 4 commits
  2. 06 Feb, 2021 2 commits
    • Tom Lane's avatar
      Disallow converting an inheritance child table to a view. · dd705a03
      Tom Lane authored
      Generally, members of inheritance trees must be plain tables (or,
      in more recent versions, foreign tables).  ALTER TABLE INHERIT
      rejects creating an inheritance relationship that has a view at
      either end.  When DefineQueryRewrite attempts to convert a relation
      to a view, it already had checks prohibiting doing so for partitioning
      parents or children as well as traditional-inheritance parents ...
      but it neglected to check that a traditional-inheritance child wasn't
      being converted.  Since the planner assumes that any inheritance
      child is a table, this led to making plans that tried to do a physical
      scan on a view, causing failures (or even crashes, in recent versions).
      
      One could imagine trying to support such a case by expanding the view
      normally, but since the rewriter runs before the planner does
      inheritance expansion, it would take some very fundamental refactoring
      to make that possible.  There are probably a lot of other parts of the
      system that don't cope well with such a situation, too.  For now,
      just forbid it.
      
      Per bug #16856 from Yang Lin.  Back-patch to all supported branches.
      (In versions before v10, this includes back-patching the portion of
      commit 501ed02c that added has_superclass().  Perhaps the lack of
      that infrastructure partially explains the missing check.)
      
      Discussion: https://postgr.es/m/16856-0363e05c6e1612fd@postgresql.org
      dd705a03
    • Michael Paquier's avatar
      Clarify some comments around SharedRecoveryState in xlog.c · f7400823
      Michael Paquier authored
      SharedRecoveryState has been switched from a boolean to an enum as of
      commit 4e87c483, but some comments still referred to it as a boolean.
      
      Author: Amul Sul
      Reviewed-by: Dilip Kumar, Kyotaro Horiguchi
      Discussion: https://postgr.es/m/CAAJ_b97Hf+1SXnm8jySpO+Fhm+-VKFAAce1T_cupUYtnE3Nxig
      f7400823
  3. 05 Feb, 2021 7 commits
    • Robert Haas's avatar
      Generalize parallel slot result handling. · 418611c8
      Robert Haas authored
      Instead of having a hard-coded behavior that we ignore missing
      tables and report all other errors, let the caller decide what
      to do by setting a callback.
      
      Mark Dilger, reviewed and somewhat revised by me. The larger patch
      series of which this is a part has also had review from Peter
      Geoghegan, Andres Freund, Álvaro Herrera, Michael Paquier, and Amul
      Sul, but I don't know whether any of them have reviewed this bit
      specifically.
      
      Discussion: http://postgr.es/m/12ED3DA8-25F0-4B68-937D-D907CFBF08E7@enterprisedb.com
      Discussion: http://postgr.es/m/5F743835-3399-419C-8324-2D424237E999@enterprisedb.com
      Discussion: http://postgr.es/m/70655DF3-33CE-4527-9A4D-DDEB582B6BA0@enterprisedb.com
      418611c8
    • Robert Haas's avatar
      Move some code from src/bin/scripts to src/fe_utils to permit reuse. · e955bd4b
      Robert Haas authored
      The parallel slots infrastructure (which implements client-side
      multiplexing of server connections doing similar things, not
      threading or multiple processes or anything like that) are moved from
      src/bin/scripts/scripts_parallel.c to src/fe_utils/parallel_slot.c.
      
      The functions consumeQueryResult() and processQueryResult() which were
      previously part of src/bin/scripts/common.c are now moved into that
      file as well, becoming static helper functions. This might need to be
      changed in the future, but currently they're not used for anything
      else.
      
      Some other functions from src/bin/scripts/common.c are moved to to
      src/fe_utils and are split up among several files.  connectDatabase(),
      connectMaintenanceDatabase(), and disconnectDatabase() are moved to
      connect_utils.c.  executeQuery(), executeCommand(), and
      executeMaintenanceCommand() are move to query_utils.c.
      handle_help_version_opts() is moved to option_utils.c.
      
      Mark Dilger, reviewed by me. The larger patch series of which this is
      a part has also had review from Peter Geoghegan, Andres Freund, Álvaro
      Herrera, Michael Paquier, and Amul Sul, but I don't know whether any
      of them have reviewed this bit specifically.
      
      Discussion: http://postgr.es/m/12ED3DA8-25F0-4B68-937D-D907CFBF08E7@enterprisedb.com
      Discussion: http://postgr.es/m/5F743835-3399-419C-8324-2D424237E999@enterprisedb.com
      Discussion: http://postgr.es/m/70655DF3-33CE-4527-9A4D-DDEB582B6BA0@enterprisedb.com
      e955bd4b
    • Heikki Linnakangas's avatar
      Fix backslash-escaping multibyte chars in COPY FROM. · c444472a
      Heikki Linnakangas authored
      If a multi-byte character is escaped with a backslash in TEXT mode input,
      and the encoding is one of the client-only encodings where the bytes after
      the first one can have an ASCII byte "embedded" in the char, we didn't
      skip the character correctly. After a backslash, we only skipped the first
      byte of the next character, so if it was a multi-byte character, we would
      try to process its second byte as if it was a separate character. If it
      was one of the characters with special meaning, like '\n', '\r', or
      another '\\', that would cause trouble.
      
      One such exmple is the byte sequence '\x5ca45c2e666f6f' in Big5 encoding.
      That's supposed to be [backslash][two-byte character][.][f][o][o], but
      because the second byte of the two-byte character is 0x5c, we incorrectly
      treat it as another backslash. And because the next character is a dot, we
      parse it as end-of-copy marker, and throw an "end-of-copy marker corrupt"
      error.
      
      Backpatch to all supported versions.
      
      Reviewed-by: John Naylor, Kyotaro Horiguchi
      Discussion: https://www.postgresql.org/message-id/a897f84f-8dca-8798-3139-07da5bb38728%40iki.fi
      c444472a
    • Etsuro Fujita's avatar
      postgres_fdw: Fix assertion in estimate_path_cost_size(). · 5e7fa189
      Etsuro Fujita authored
      Commit 08d2d58a added an assertion assuming that the retrieved_rows
      estimate for a foreign relation, which is re-used to cost pre-sorted
      foreign paths with local stats, is set to at least one row in
      estimate_path_cost_size(), which isn't correct because if the relation
      is a foreign table with tuples=0, the estimate would be set to 0 there
      when not using remote estimates.
      
      Per bug #16807 from Alexander Lakhin.  Back-patch to v13 where the
      aforementioned commit went in.
      
      Author: Etsuro Fujita
      Reviewed-by: Kyotaro Horiguchi
      Discussion: https://postgr.es/m/16807-9fe4e08fbaa5c7ce%40postgresql.org
      5e7fa189
    • Tom Lane's avatar
      Fix bug in HashAgg's selective-column-spilling logic. · 0ff865fb
      Tom Lane authored
      Commit 23023022 taught nodeAgg.c that, when spilling tuples from
      memory in an oversized hash aggregation, it only needed to spill
      input columns referenced in the node's tlist and quals.  Unfortunately,
      that's wrong: we also have to save the grouping columns.  The error
      is masked in common cases because the grouping columns also appear
      in the tlist, but that's not necessarily true.  The main category
      of plans where it's not true seem to come from semijoins ("WHERE
      outercol IN (SELECT innercol FROM innertable)") where the innercol
      needs an implicit promotion to make it comparable to the outercol.
      The grouping column will be "innercol::promotedtype", but that
      expression appears nowhere in the Agg node's own tlist and quals;
      only the bare "innercol" is found in the tlist.
      
      I spent quite a bit of time looking for a suitable regression test
      case for this, without much success.  If the number of distinct
      values of the innercol is large enough to make spilling happen,
      the planner tends to prefer a non-HashAgg plan, at least for
      problem sizes that are reasonable to use in the regression tests.
      So, no new regression test.  However, this patch does demonstrably
      fix the originally-reported test case.
      
      Per report from s.p.e (at) gmx-topmail.de.  Backpatch to v13
      where the troublesome code came in.
      
      Discussion: https://postgr.es/m/trinity-1c565d44-159f-488b-a518-caf13883134f-1611835701633@3c-app-gmx-bap78
      0ff865fb
    • Thomas Munro's avatar
      Tab-complete CREATE DATABASE ... LOCALE. · e1c02d92
      Thomas Munro authored
      Author: Ian Lawrence Barwick <barwick@gmail.com>
      Discussion: https://postgr.es/m/CAB8KJ%3Dh0XO2CB4QbLBc1Tm9Bg5wzSGQtT-eunaCmrghJp4nqdA%40mail.gmail.com
      e1c02d92
    • Tom Lane's avatar
      Fix YA incremental sort bug. · 82e0e293
      Tom Lane authored
      switchToPresortedPrefixMode() did the wrong thing if it detected
      a batch boundary just at the last tuple of a fullsort group.
      
      The initially-reported symptom was a "retrieved too many tuples in a
      bounded sort" error, but the test case added here just silently gives
      the wrong answer without this patch.
      
      I (tgl) am not really happy about committing this patch without review
      from the incremental-sort authors, but they seem AWOL and we are hard
      against a release deadline.  This does demonstrably make some cases
      better, anyway.
      
      Per bug #16846 from Yoran Heling.  Back-patch to v13 where incremental
      sort was introduced.
      
      Neil Chen
      
      Discussion: https://postgr.es/m/16846-ae49f51ac379a4cb@postgresql.org
      82e0e293
  4. 04 Feb, 2021 7 commits
    • Peter Geoghegan's avatar
      Harden nbtree page deletion. · c34787f9
      Peter Geoghegan authored
      Add some additional defensive checks in the second phase of index
      deletion to detect and report index corruption during VACUUM, and to
      avoid having VACUUM become stuck in more cases.  The code is still not
      robust in the presence of a circular chain of sibling links, though it's
      not clear whether that really matters.  This is follow-up work to commit
      3a01f68e.
      
      The new defensive checks rely on the assumption that there can be no
      more than one VACUUM operation running for an index at any given time.
      Remove an old comment suggesting that multiple concurrent VACUUMs need
      to be considered here.  This concern now seems highly unlikely to have
      any real validity, since we clearly rely on the same assumption in
      several other places.  For example, there are much more recent comments
      that appear in the same function (added by commit efada2b8) that make
      the same assumption.
      
      Also add a CHECK_FOR_INTERRUPTS() to the relevant code path.  Contrary
      to comments added by commit 3a01f68e, it is actually possible to handle
      interrupts here, at least in the common case where processing takes
      place at the leaf level.  We only hold a pin on leafbuf/target page when
      stepping right at the leaf level.
      
      No backpatch due to the lack of complaints following hardening added to
      the same area by commit 3a01f68e.
      c34787f9
    • Heikki Linnakangas's avatar
      Fix small error in COPY FROM progress reporting. · 2f86ab30
      Heikki Linnakangas authored
      The # of bytes processed was accumulated slightly incorrectly. After
      loading more data to the input buffer, we added the number of bytes in
      the buffer to the sum. But in case of multi-byte characters or escapes,
      there can be a few unprocessed bytes left over from previous load in the
      buffer. Those bytes got counted twice.
      2f86ab30
    • Peter Eisentraut's avatar
      Refactor Windows error message for easier translation · 3c78e056
      Peter Eisentraut authored
      In the error messages referring to the user right "Lock pages in
      memory", this is a term from the Windows OS, so it should be
      translated in accordance with the OS localization.  Refactor the error
      messages so this is easier and clearer.  Also fix the capitalization
      to match the existing capitalization in the OS.
      3c78e056
    • Michael Paquier's avatar
      Ensure unlinking of old index file with REINDEX (TABLESPACE) · 5128483d
      Michael Paquier authored
      The original versions of the patch included this part, but a mismerge
      from my side has made this piece go missing.  Oversight in c5b28604.
      5128483d
    • Michael Paquier's avatar
      Clarify comment in tablesync.c · fc749bc7
      Michael Paquier authored
      Author: Peter Smith
      Reviewed-by: Amit Kapila, Michael Paquier, Euler Taveira
      Discussion: https://postgr.es/m/CAHut+Pt9_T6pWar0FLtPsygNmme8HPWPdGUyZ_8mE1Yvjdf0ZA@mail.gmail.com
      fc749bc7
    • Michael Paquier's avatar
      Add TABLESPACE option to REINDEX · c5b28604
      Michael Paquier authored
      This patch adds the possibility to move indexes to a new tablespace
      while rebuilding them.  Both the concurrent and the non-concurrent cases
      are supported, and the following set of restrictions apply:
      - When using TABLESPACE with a REINDEX command that targets a
      partitioned table or index, all the indexes of the leaf partitions are
      moved to the new tablespace.  The tablespace references of the non-leaf,
      partitioned tables in pg_class.reltablespace are not changed. This
      requires an extra ALTER TABLE SET TABLESPACE.
      - Any index on a toast table rebuilt as part of a parent table is kept
      in its original tablespace.
      - The operation is forbidden on system catalogs, including trying to
      directly move a toast relation with REINDEX.  This results in an error
      if doing REINDEX on a single object.  REINDEX SCHEMA, DATABASE and
      SYSTEM skip system relations when TABLESPACE is used.
      
      Author: Alexey Kondratov, Michael Paquier, Justin Pryzby
      Reviewed-by: Álvaro Herrera, Michael Paquier
      Discussion: https://postgr.es/m/8a8f5f73-00d3-55f8-7583-1375ca8f6a91@postgrespro.ru
      c5b28604
    • Tom Lane's avatar
      Avoid crash when rolling back within a prepared statement. · 9624321e
      Tom Lane authored
      If a portal is used to run a prepared CALL or DO statement that
      contains a ROLLBACK, PortalRunMulti fails because the portal's
      statement list gets cleared by the rollback.  (Since the grammar
      doesn't allow CALL/DO in PREPARE, the only easy way to get to this is
      via extended query protocol, which treats all inputs as prepared
      statements.)  It's difficult to avoid resetting the portal early
      because of resource-management issues, so work around this by teaching
      PortalRunMulti to be wary of portal->stmts having suddenly become NIL.
      
      The crash has only been seen to occur in v13 and HEAD (as a
      consequence of commit 1cff1b95 having added an extra touch of
      portal->stmts).  But even before that, the code involved touching a
      List that the portal no longer has any claim on.  In the test case at
      hand, the List will still exist because of another refcount on the
      cached plan; but I'm far from convinced that it's impossible for the
      cached plan to have been dropped by the time control gets back to
      PortalRunMulti.  Hence, backpatch to v11 where nested transactions
      were added.
      
      Thomas Munro and Tom Lane, per bug #16811 from James Inform
      
      Discussion: https://postgr.es/m/16811-c1b599b2c6c2d622@postgresql.org
      9624321e
  5. 03 Feb, 2021 3 commits
    • Robert Haas's avatar
      Factor pattern-construction logic out of processSQLNamePattern. · 2c8726c4
      Robert Haas authored
      The logic for converting the shell-glob-like syntax supported by
      utilities like psql and pg_dump to regular expression is
      extracted into a new function patternToSQLRegex. The existing
      function processSQLNamePattern now uses this function as a
      subroutine.
      
      patternToSQLRegex is a little more general than what is required
      by processSQLNamePattern. That function is only interested in
      patterns that can have up to 2 parts, a schema and a relation;
      but patternToSQLRegex can limit the maximum number of parts to
      between 1 and 3, so that patterns can look like either
      "database.schema.relation", "schema.relation", or "relation"
      depending on how it's invoked and what the user specifies.
      
      processSQLNamePattern only passes two buffers, so works exactly
      the same as before, always interpreting the pattern as either
      a "schema.relation" pattern or a "relation" pattern. But,
      future callers can use this function in other ways.
      
      Mark Dilger, reviewed by me. The larger patch series of which this is
      a part has also had review from Peter Geoghegan, Andres Freund, Álvaro
      Herrera, Michael Paquier, and Amul Sul, but I don't know whether
      any of them have reviewed this bit specifically.
      
      Discussion: http://postgr.es/m/12ED3DA8-25F0-4B68-937D-D907CFBF08E7@enterprisedb.com
      Discussion: http://postgr.es/m/5F743835-3399-419C-8324-2D424237E999@enterprisedb.com
      Discussion: http://postgr.es/m/70655DF3-33CE-4527-9A4D-DDEB582B6BA0@enterprisedb.com
      2c8726c4
    • Tom Lane's avatar
      Remove special BKI_LOOKUP magic for namespace and role OIDs. · ba0faf81
      Tom Lane authored
      Now that commit 62f34097 attached BKI_LOOKUP annotation to all the
      namespace and role OID columns in the catalogs, there's no real reason
      to have the magic PGNSP and PGUID symbols.  Get rid of them in favor
      of implementing those lookups according to genbki.pl's normal pattern.
      
      This means that in the catalog headers, BKI_DEFAULT(PGNSP) becomes
      BKI_DEFAULT(pg_catalog), which seems a lot more transparent.
      BKI_DEFAULT(PGUID) becomes BKI_DEFAULT(POSTGRES), which is perhaps
      less so; but you can look into pg_authid.dat to discover that
      POSTGRES is the nonce name for the bootstrap superuser.
      
      This change also means that if we ever need cross-references in the
      initial catalog data to any of the other built-in roles besides
      POSTGRES, or to some other built-in schema besides pg_catalog,
      we can just do it.
      
      No catversion bump here, as there's no actual change in the contents
      of postgres.bki.
      
      Discussion: https://postgr.es/m/3240355.1612129197@sss.pgh.pa.us
      ba0faf81
    • Peter Eisentraut's avatar
      pg_dump: Fix dumping of inherited generated columns · 0bf83648
      Peter Eisentraut authored
      Generation expressions of generated columns are always inherited, so
      there is no need to set them separately in child tables, and there is
      no syntax to do so either.  The code previously used the code paths
      for the handling of default values, for which different rules apply;
      in particular it might want to set a default value explicitly for an
      inherited column.  This resulted in unrestorable dumps.  For generated
      columns, just skip them in inherited tables.
      Reviewed-by: default avatarTom Lane <tgl@sss.pgh.pa.us>
      Discussion: https://www.postgresql.org/message-id/flat/15830.1575468847%40sss.pgh.pa.us
      0bf83648
  6. 02 Feb, 2021 7 commits
    • Tom Lane's avatar
      Retire findoidjoins. · ef3d4613
      Tom Lane authored
      In the wake of commit 62f34097, we no longer need this tool.
      
      Discussion: https://postgr.es/m/3240355.1612129197@sss.pgh.pa.us
      ef3d4613
    • Tom Lane's avatar
      Build in some knowledge about foreign-key relationships in the catalogs. · 62f34097
      Tom Lane authored
      This follows in the spirit of commit dfb75e47, which created primary
      key and uniqueness constraints to improve the visibility of constraints
      imposed on the system catalogs.  While our catalogs contain many
      foreign-key-like relationships, they don't quite follow SQL semantics,
      in that the convention for an omitted reference is to write zero not
      NULL.  Plus, we have some cases in which there are arrays each of whose
      elements is supposed to be an FK reference; SQL has no way to model that.
      So we can't create actual foreign key constraints to describe the
      situation.  Nonetheless, we can collect and use knowledge about these
      relationships.
      
      This patch therefore adds annotations to the catalog header files to
      declare foreign-key relationships.  (The BKI_LOOKUP annotations cover
      simple cases, but we weren't previously distinguishing which such
      columns are allowed to contain zeroes; we also need new markings for
      multi-column FK references.)  Then, Catalog.pm and genbki.pl are
      taught to collect this information into a table in a new generated
      header "system_fk_info.h".  The only user of that at the moment is
      a new SQL function pg_get_catalog_foreign_keys(), which exposes the
      table to SQL.  The oidjoins regression test is rewritten to use
      pg_get_catalog_foreign_keys() to find out which columns to check.
      Aside from removing the need for manual maintenance of that test
      script, this allows it to cover numerous relationships that were not
      checked by the old implementation based on findoidjoins.  (As of this
      commit, 217 relationships are checked by the test, versus 181 before.)
      
      Discussion: https://postgr.es/m/3240355.1612129197@sss.pgh.pa.us
      62f34097
    • Tom Lane's avatar
      Doc: consistently identify OID catalog columns that can be zero. · 47933140
      Tom Lane authored
      Not all OID-reference columns that can contain zeroes (indicating
      "no reference") were explicitly marked in catalogs.sgml.  Fix that,
      and try to make the style a little more consistent while at it ---
      for example, consistently write "zero" not "0" for these cases.
      
      Joel Jacobson and Tom Lane
      
      Discussion: https://postgr.es/m/4ed9a372-7bf9-479a-926c-ae8e774717a8@www.fastmail.com
      47933140
    • Tom Lane's avatar
      Remove extra increment of plpgsql's statement counter for FOR loops. · dfcc46fe
      Tom Lane authored
      This left gaps in the internal statement numbering, which is not
      terribly harmful (else we'd have noticed sooner), but it's not
      great either.
      
      Oversight in bbd5c207; backpatch to v12 where that came in.
      
      Pavel Stehule
      
      Discussion: https://postgr.es/m/CAFj8pRDXyQaJmpotNTQVc-t-WxdWZC35V2PnmwOaV1-taidFWA@mail.gmail.com
      dfcc46fe
    • Tom Lane's avatar
      Fix ancient memory leak in contrib/auto_explain. · 5c0f7cc5
      Tom Lane authored
      The ExecutorEnd hook is invoked in a context that could be quite
      long-lived, not the executor's own per-query context as I think
      we were sort of assuming.  Thus, any cruft generated while producing
      the EXPLAIN output could accumulate over multiple queries.  This can
      result in spectacular leakage if log_nested_statements is on, and
      even without that I'm surprised nobody complained before.
      
      To fix, just switch into the executor's context so that anything we
      allocate will be released when standard_ExecutorEnd frees the executor
      state.  We might as well nuke the code's retail pfree of the explain
      output string, too; that's laughably inadequate to the need.
      
      Japin Li, per report from Jeff Janes.  This bug is old, so
      back-patch to all supported branches.
      
      Discussion: https://postgr.es/m/CAMkU=1wCVtbeRn0s9gt12KwQ7PLXovbpM8eg25SYocKW3BT4hg@mail.gmail.com
      5c0f7cc5
    • Peter Eisentraut's avatar
      Improve confusing variable names · 1d71f3c8
      Peter Eisentraut authored
      The prototype calls the second argument of
      pgstat_progress_update_multi_param() "index", and some callers name
      their local variable that way.  But when the surrounding code deals
      with index relations, this is confusing, and in at least one case
      shadowed another variable that is referring to an index relation.
      Adjust those call sites to have clearer local variable naming, similar
      to existing callers in indexcmds.c.
      1d71f3c8
    • Michael Paquier's avatar
      Remove unused column atttypmod from initial tablesync query · 4ad31bb2
      Michael Paquier authored
      The initial tablesync done by logical replication used a query to fetch
      the information of a relation's columns that included atttypmod, but it
      was left unused.  This was added by 7c4f5240.
      
      Author: Euler Taveira
      Reviewed-by: Önder Kalacı, Amit Langote, Japin Li
      Discussion: https://postgr.es/m/CAHE3wggb715X+mK_DitLXF25B=jE6xyNCH4YOwM860JR7HarGQ@mail.gmail.com
      4ad31bb2
  7. 01 Feb, 2021 8 commits
  8. 31 Jan, 2021 2 commits