# PostgreSQL Weekly News - May  2, 2021

Person of the week: 
[https://postgresql.life/post/corey_huinker/](https://postgresql.life/post/corey_huinker/)

# PostgreSQL Product News

The observability diagram at pgstats.dev has been updated.
[https://pgstats.dev/](https://pgstats.dev/)

# PostgreSQL Jobs for May

[https://archives.postgresql.org/pgsql-jobs/2021-05/](https://archives.postgresql.org/pgsql-jobs/2021-05/)

# PostgreSQL in the News

Planet PostgreSQL: 
[https://planet.postgresql.org/](https://planet.postgresql.org/)

PostgreSQL Weekly News is brought to you this week by David Fetter

Submit news and announcements by Sunday at 3:00pm PST8PDT to [email protected].

# Applied Patches

Tom Lane pushed:

- Update comments for rewriteTargetListIU(). This function's behavior for UPDATE
  on a trigger-updatable view was justified by analogy to what preptlist.c used
  to do for UPDATE on regular tables.  Since preptlist.c hasn't done that since
  86dc90056, that argument is no longer sensible, let alone convincing.  I think
  we do still need it to act that way, so update the comment to explain why.
  
[https://git.postgresql.org/pg/commitdiff/08a986966524e522914b96e4398a4bebf942b298](https://git.postgresql.org/pg/commitdiff/08a986966524e522914b96e4398a4bebf942b298)

- Doc: document EXTRACT(JULIAN ...), improve Julian Date explanation. For some
  reason, the "julian" option for extract()/date_part() has never gotten listed
  in the manual.  Also, while Appendix B mentioned in passing that we don't
  conform to the usual astronomical definition that a Julian date starts at noon
  UTC, it was kind of vague about what we do instead.  Clarify that, and add an
  example showing how to get the astronomical definition if you want it.  It's
  been like this for ages, so back-patch to all supported branches.  Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/79a5928ebcb726b7061bf265b5c6990e835e8c4f](https://git.postgresql.org/pg/commitdiff/79a5928ebcb726b7061bf265b5c6990e835e8c4f)

- Remove rewriteTargetListIU's expansion of view targetlists in UPDATE. Commit
  2ec993a7c, which added triggers on views, modified the rewriter to add dummy
  entries like "SET x = x" for all columns that weren't actually being updated
  by the user in any UPDATE directed at a view. That was needed at the time to
  produce a complete "NEW" row to pass to the trigger.  Later it was found to
  cause problems for ordinary updatable views, so commit cab5dc5da restricted it
  to happen only for trigger-updatable views.  But in the wake of commit
  86dc90056, we really don't need it at all.  nodeModifyTable.c populates the
  trigger "OLD" row from the whole-row variable that is generated for the view,
  and then it computes the "NEW" row using that old row and the UPDATE
  targetlist.  So there is no need for the UPDATE tlist to have dummy entries,
  any more than it needs them for regular tables or other types of views.  (The
  comments for rewriteTargetListIU suggest that we must do this for correct
  expansion of NEW references in rules, but I now think that that was just lazy
  comment editing in 2ec993a7c.  If we didn't need it for rules on views before
  there were triggers, we don't need it after that.)  This essentially
  propagates 86dc90056's decision that we don't need dummy column updates into
  the view case.  Aside from making the different cases more uniform and hence
  possibly forestalling future bugs, it ought to save a little bit of
  rewriter/planner effort.  Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/04942bffd0aa9bd0d143d99b473342eb9ecee88b](https://git.postgresql.org/pg/commitdiff/04942bffd0aa9bd0d143d99b473342eb9ecee88b)

- Doc: fix discussion of how to get real Julian Dates. Somehow I'd convinced
  myself that rotating to UTC-12 was the way to do this, but upon further
  review, it's definitely UTC+12.  Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/c93f8f3b8d3bc780892e2bf11192fbdd136fddfe](https://git.postgresql.org/pg/commitdiff/c93f8f3b8d3bc780892e2bf11192fbdd136fddfe)

- Add heuristic incoming-message-size limits in the server. We had a report of
  confusing server behavior caused by a client bug that sent junk to the server:
  the server thought the junk was a very long message length and waited
  patiently for data that would never come.  We can reduce the risk of that by
  being less trusting about message lengths.  For a long time, libpq has had a
  heuristic rule that it wouldn't believe large message size words, except for a
  small number of message types that are expected to be (potentially) long.
  This provides some defense against loss of message-boundary sync and other
  corrupted-data cases.  The server does something similar, except that up to
  now it only limited the lengths of messages received during the connection
  authentication phase.  Let's do the same as in libpq and put restrictions on
  the allowed length of all messages, while distinguishing between message types
  that are expected to be long and those that aren't.  I used a limit of 10000
  bytes for non-long messages.  (libpq's corresponding limit is 30000 bytes, but
  given the asymmetry of the FE/BE protocol, there's no good reason why the
  numbers should be the same.)  Experimentation suggests that this is at least a
  factor of 10, maybe a factor of 100, more than we really need; but plenty of
  daylight seems desirable to avoid false positives. In any case we can adjust
  the limit based on beta-test results.  For long messages, set a limit of
  MaxAllocSize - 1, which is the most that we can absorb into the StringInfo
  buffer that the message is collected in.  This just serves to make sure that a
  bogus message size is reported as such, rather than as a confusing gripe about
  not being able to enlarge a string buffer.  While at it, make sure that
  non-mainline code paths (such as COPY FROM STDIN) are as paranoid as
  SocketBackend is, and validate the message type code before believing the
  message length. This provides an additional guard against getting stuck on
  corrupted input.  Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/9626325da5e8e23ff90091bc96535495d350f06e](https://git.postgresql.org/pg/commitdiff/9626325da5e8e23ff90091bc96535495d350f06e)

- Fix some more omissions in pg_upgrade's tests for non-upgradable types.
  Commits 29aeda6e4 et al closed up some oversights involving not checking for
  non-upgradable types within container types, such as arrays and ranges.
  However, I only looked at version.c, failing to notice that there were
  substantially-equivalent tests in check.c.  (The division of responsibility
  between those files is less than clear...)  In addition, because genbki.pl
  does not guarantee that auto-generated rowtype OIDs will hold still across
  versions, we need to consider that the composite type associated with a system
  catalog or view is non-upgradable.  It seems unlikely that someone would have
  a user column declared that way, but if they did, trying to read it in another
  PG version would likely draw "no such pg_type OID" failures, thanks to the
  type OID embedded in composite Datums.  To support the composite and 
`reg*`-type
  cases, extend the recursive query that does the search to allow any base query
  that returns a column of pg_type OIDs, rather than limiting it to exactly one
  starting type.  As before, back-patch to all supported branches.  Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/57c081de0afcd01bf47c46f015bf8886b01c2c21](https://git.postgresql.org/pg/commitdiff/57c081de0afcd01bf47c46f015bf8886b01c2c21)

- Improve wording of some pg_upgrade failure reports. Don't advocate dropping a
  whole table when dropping a column would serve.  While at it, try to make the
  layout of these messages a bit cleaner and more consistent.  Per suggestion
  from Daniel Gustafsson.  No back-patch, as we generally don't like to churn
  translatable messages in released branches.  Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/c9c37ae03fea0c8ad467392ddf03940b61974935](https://git.postgresql.org/pg/commitdiff/c9c37ae03fea0c8ad467392ddf03940b61974935)

- Disallow calling anything but plain functions via the fastpath API. Reject
  aggregates, window functions, and procedures.  Aggregates failed anyway,
  though with a somewhat obscure error message. Window functions would hit an
  Assert or null-pointer dereference. Procedures seemed to work as long as you
  didn't try to do transaction control, but (a) transaction control is sort of
  the point of a procedure, and (b) it's not entirely clear that no bugs lurk in
  that path.  Given the lack of testing of this area, it seems safest to be
  conservative in what we support.  Also reject proretset functions, as the
  fastpath protocol can't support returning a set.  Also remove an
  easily-triggered assertion that the given OID isn't 0; the subsequent lookups
  can handle that case themselves.  Per report from Theodor-Arsenij
  Larionov-Trichkin. Back-patch to all supported branches.  (The procedure angle
  only applies in v11+, of course.)  Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/2efcd502e56a528f75ec8e88c02a287ad3457d77](https://git.postgresql.org/pg/commitdiff/2efcd502e56a528f75ec8e88c02a287ad3457d77)

- Doc: update libpq's documentation for PQfn(). Mention specifically that you
  can't call aggregates, window functions, or procedures this way (the inability
  to call SRFs was already mentioned).  Also, the claim that PQfn doesn't
  support NULL arguments or results has been a lie since we invented protocol
  3.0.  Not sure why this text was never updated for that, but do it now.
  Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/386e64ea5abf346d887c21ea8869317838ba19b5](https://git.postgresql.org/pg/commitdiff/386e64ea5abf346d887c21ea8869317838ba19b5)

- Doc: add an example of a self-referential foreign key to ddl.sgml. While we've
  always allowed such cases, the documentation didn't say you could do it.
  Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/e6f9539dc32473793c03cbe95bc099ee0a199c73](https://git.postgresql.org/pg/commitdiff/e6f9539dc32473793c03cbe95bc099ee0a199c73)

Amit Kapila pushed:

- Fix typo in reorderbuffer.c. Author: Peter Smith Discussion:
  
[https://postgr.es/m/CAHut+PtvzuYY0zu=dvrk_wvz5wgos1+otzwgewqjha1ncos...@mail.gmail.com](https://postgr.es/m/CAHut+PtvzuYY0zu=dvrk_wvz5wgos1+otzwgewqjha1ncos...@mail.gmail.com)
  
[https://git.postgresql.org/pg/commitdiff/6d2e87a077b3c2394e4adb8eb226b3dcfe3f3346](https://git.postgresql.org/pg/commitdiff/6d2e87a077b3c2394e4adb8eb226b3dcfe3f3346)

- Avoid sending prepare multiple times while decoding. We send the prepare for
  the concurrently aborted xacts so that later when rollback prepared is decoded
  and sent, the downstream should be able to rollback such a xact. For
  'streaming' case (when we send changes for in-progress transactions), we were
  sending prepare twice when concurrent abort was detected.  Author: Peter Smith
  Reviewed-by: Amit Kapila Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/f25a4584c6f56f3407f8f8734c78f2a87e4b77e8](https://git.postgresql.org/pg/commitdiff/f25a4584c6f56f3407f8f8734c78f2a87e4b77e8)

- Fix Logical Replication of Truncate in synchronous commit mode. The Truncate
  operation acquires an exclusive lock on the target relation and indexes. It
  then waits for logical replication of the operation to finish at commit. Now
  because we are acquiring the shared lock on the target index to get index
  attributes in pgoutput while sending the changes for the Truncate operation,
  it leads to a deadlock.  Actually, we don't need to acquire a lock on the
  target index as we build the cache entry using a historic snapshot and all the
  later changes are absorbed while decoding WAL. So, we wrote a special purpose
  function for logical replication to get a bitmap of replica identity attribute
  numbers where we get that information without locking the target index.  We
  decided not to backpatch this as there doesn't seem to be any field complaint
  about this issue since it was introduced in commit 5dfd1e5a in v11.
  Reported-by: Haiying Tang Author: Takamichi Osumi, test case by Li Japin
  Reviewed-by: Amit Kapila, Ajin Cherian Discussion:
  
[https://postgr.es/m/os0pr01mb6113c2499c7dc70ee55adb82fb...@os0pr01mb6113.jpnprd01.prod.outlook.com](https://postgr.es/m/os0pr01mb6113c2499c7dc70ee55adb82fb...@os0pr01mb6113.jpnprd01.prod.outlook.com)
  
[https://git.postgresql.org/pg/commitdiff/e7eea52b2d61917fbbdac7f3f895e4ef636e935b](https://git.postgresql.org/pg/commitdiff/e7eea52b2d61917fbbdac7f3f895e4ef636e935b)

- Use HTAB for replication slot statistics. Previously, we used to use the array
  of size max_replication_slots to store stats for replication slots. But that
  had two problems in the cases where a message for dropping a slot gets lost:
  1) the stats for the new slot are not recorded if the array is full and 2)
  writing beyond the end of the array if the user reduces the
  max_replication_slots.  This commit uses HTAB for replication slot statistics,
  resolving both problems. Now, pgstat_vacuum_stat() search for all the dead
  replication slots in stats hashtable and tell the collector to remove them. To
  avoid showing the stats for the already-dropped slots,
  pg_stat_replication_slots view searches slot stats by the slot name taken from
  pg_replication_slots.  Also, we send a message for creating a slot at slot
  creation, initializing the stats. This reduces the possibility that the stats
  are accumulated into the old slot stats when a message for dropping a slot
  gets lost.  Reported-by: Andres Freund Author: Sawada Masahiko, test case by
  Vignesh C Reviewed-by: Amit Kapila, Vignesh C, Dilip Kumar Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/3fa17d37716f978f80dfcdab4e7c73f3a24e7a48](https://git.postgresql.org/pg/commitdiff/3fa17d37716f978f80dfcdab4e7c73f3a24e7a48)

- Another try to fix the test case added by commit f5fc2f5b23. As per analysis,
  it appears that the 'drop slot' message from the previous test and 'create
  slot' message of the new test are either missed or not yet delivered to the
  stats collector due to which we will still see the stats from the old slot.
  This can happen rarely which could be the reason that we are seeing some
  failures in the buildfarm randomly. To avoid that we are using a different
  slot name for the tests in test_decoding/sql/stats.sql.  Reported-by: Tom Lane
  based on buildfarm reports Author: Sawada Masahiko Reviewed-by: Amit Kapila,
  Vignesh C Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/51ef9173030cc196c6633ae82b7b32f404b0f768](https://git.postgresql.org/pg/commitdiff/51ef9173030cc196c6633ae82b7b32f404b0f768)

- Fix the bugs in selecting the transaction for streaming. There were two
  problems: a. We were always selecting the next available txn instead of
  selecting it when it is larger than the previous transaction. b. We were
  selecting the transactions which haven't made any changes to the database
  (base snapshot is not set). Later it was hitting an Assert because we don't
  decode such transactions and the changes in txn remain as it is. It is better
  not to choose such transactions for streaming in the first place.
  Reported-by: Haiying Tang Author: Dilip Kumar Reviewed-by: Amit Kapila
  Discussion:
  
[https://postgr.es/m/os0pr01mb61133b94e63177040f7ecda1fb...@os0pr01mb6113.jpnprd01.prod.outlook.com](https://postgr.es/m/os0pr01mb61133b94e63177040f7ecda1fb...@os0pr01mb6113.jpnprd01.prod.outlook.com)
  
[https://git.postgresql.org/pg/commitdiff/ee4ba01dbbc31daa083f434ecd603a80bbe50501](https://git.postgresql.org/pg/commitdiff/ee4ba01dbbc31daa083f434ecd603a80bbe50501)

Peter Eisentraut pushed:

- Remove unused function argument. This was already unused in the initial commit
  257836a75585934cc05ed7a80bccf8190d41e056.  Apparently, it was used in an
  earlier proposed patch version.
  
[https://git.postgresql.org/pg/commitdiff/3cbea581c76e86d51b8f2babf116e643847e7712](https://git.postgresql.org/pg/commitdiff/3cbea581c76e86d51b8f2babf116e643847e7712)

- Fix pg_upgrade test on Cygwin. The verification of permissions doesn't succeed
  on Cygwin, because the required feature is not implemented for Cygwin at the
  moment.  So skip this part of the test, like MinGW already does.
  
[https://git.postgresql.org/pg/commitdiff/38c9a5938ac5e1409b42677fee970a12632852ee](https://git.postgresql.org/pg/commitdiff/38c9a5938ac5e1409b42677fee970a12632852ee)

- pg_hba.conf.sample: Reword connection type section. Improve the wording in the
  connection type section of pg_hba.conf.sample a bit.  After the hostgssenc
  part was added on, the whole thing became a bit wordy, and it's also a bit
  inaccurate for example in that the current wording for "host" appears to say
  that it does not apply to GSS-encrypted connections.  Discussion:
  
[https://www.postgresql.org/message-id/flat/fc06dcc5-513f-e944-cd07-ba51dd7c6916%40enterprisedb.com](https://www.postgresql.org/message-id/flat/fc06dcc5-513f-e944-cd07-ba51dd7c6916%40enterprisedb.com)
  
[https://git.postgresql.org/pg/commitdiff/3a948ea0a2ced719f26e725b030558f2e4ab1d8e](https://git.postgresql.org/pg/commitdiff/3a948ea0a2ced719f26e725b030558f2e4ab1d8e)

- psql: Fix line continuation prompts for unbalanced parentheses. This was
  broken by a silly mistake in e717a9a18b2e34c9c40e5259ad4d31cd7e420750.
  Reported-by: Jeff Janes <[email protected]> Author: Justin Pryzby
  <[email protected]> Discussion:
  
[https://www.postgresql.org/message-id/CAMkU=1zKGWEJdBbYKw7Tn7cJmYR_UjgdcXTPDqJj=dnwcet...@mail.gmail.com](https://www.postgresql.org/message-id/CAMkU=1zKGWEJdBbYKw7Tn7cJmYR_UjgdcXTPDqJj=dnwcet...@mail.gmail.com)
  
[https://git.postgresql.org/pg/commitdiff/d9a9f4b4b92ad39e3c4e6600dc61d5603ddd6e24](https://git.postgresql.org/pg/commitdiff/d9a9f4b4b92ad39e3c4e6600dc61d5603ddd6e24)

Michaël Paquier pushed:

- Add more tests with triggers on partitions for logical replication. The tuple
  routing logic used by a logical replication worker can fire triggers on
  relations part of a partition tree, but there was no test coverage in this
  area.  The existing script 003_constraints.pl included something, but nothing
  when a tuple is applied across partitioned tables on a subscriber.  Author:
  Amit Langote Discussion:
  
[https://postgr.es/m/os0pr01mb611383fa0fe92eb9de21946afb...@os0pr01mb6113.jpnprd01.prod.outlook.com](https://postgr.es/m/os0pr01mb611383fa0fe92eb9de21946afb...@os0pr01mb6113.jpnprd01.prod.outlook.com)
  
[https://git.postgresql.org/pg/commitdiff/2ecfeda3e916f2a1123f818018d9d35908a499ac](https://git.postgresql.org/pg/commitdiff/2ecfeda3e916f2a1123f818018d9d35908a499ac)

- Fix pg_identify_object_as_address() with event triggers. Attempting to use
  this function with event triggers failed, as, since its introduction in
  a676201, this code has never associated an object name with event triggers.
  This addresses the failure by adding the event trigger name to the set
  defining its object address.  Note that regression tests are added within
  event_trigger and not object_address to avoid issues with concurrent
  connections in parallel schedules.  Author: Joel Jacobson Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  Backpatch-through: 9.6
  
[https://git.postgresql.org/pg/commitdiff/f7aab36d61fd2fdbd949d5880247e8cae9ee4be0](https://git.postgresql.org/pg/commitdiff/f7aab36d61fd2fdbd949d5880247e8cae9ee4be0)

- Fix use-after-release issue with pg_identify_object_as_address(). Spotted by
  buildfarm member prion, with -DRELCACHE_FORCE_RELEASE.  Introduced in f7aab36.
  Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  Backpatch-through: 9.6
  
[https://git.postgresql.org/pg/commitdiff/f93f0b5b25068807051edb2f3510614b69bb79ff](https://git.postgresql.org/pg/commitdiff/f93f0b5b25068807051edb2f3510614b69bb79ff)

- doc: Fix description of target_session_attrs=prefer-standby. If no standbys
  can be found in the set of connection points provided, the fallback behavior
  is "any", and not "all" that does not exist.  Author: Greg Nancarrow
  Reviewed-by: Laurenz Albe Discussion:
  
[https://postgr.es/m/cajcof-fdacv8qcpwh7k5yh6zfxzeuwzowu4scwq2zfx4cdk...@mail.gmail.com](https://postgr.es/m/cajcof-fdacv8qcpwh7k5yh6zfxzeuwzowu4scwq2zfx4cdk...@mail.gmail.com)
  
[https://git.postgresql.org/pg/commitdiff/2977f244bc7e64e046364122be3fef08aa6efef9](https://git.postgresql.org/pg/commitdiff/2977f244bc7e64e046364122be3fef08aa6efef9)

Álvaro Herrera pushed:

- psql: tab-complete ALTER ... DETACH CONCURRENTLY / FINALIZE. New keywords per
  71f4c8c6f74b.  Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/6dd1042eda0acdabaab352c19b783288de62b587](https://git.postgresql.org/pg/commitdiff/6dd1042eda0acdabaab352c19b783288de62b587)

- Allow a partdesc-omitting-partitions to be cached. Makes partition descriptor
  acquisition faster during the transient period in which a partition is in the
  process of being detached.  This also adds the restriction that only one
  partition can be in pending-detach state for a partitioned table.  While at
  it, return find_inheritance_children() API to what it was before 71f4c8c6f74b,
  and create a separate find_inheritance_children_extended() that returns
  detailed info about detached partitions.  (This incidentally fixes a bug in
  8aba9322511 whereby a memory context holding a transient partdesc is
  reparented to a NULL PortalContext, leading to permanent leak of that memory.
  The fix is to no longer rely on reparenting contexts to PortalContext.
  Reported by Amit Langote.)  Per gripe from Amit Langote Discussion:
  
[https://postgr.es/m/ca+hiwqfgpp1lxjzobygt9rpvtjxxkg5qg2+xch2z1q7krqz...@mail.gmail.com](https://postgr.es/m/ca+hiwqfgpp1lxjzobygt9rpvtjxxkg5qg2+xch2z1q7krqz...@mail.gmail.com)
  
[https://git.postgresql.org/pg/commitdiff/d6b8d29419df0efad57f95c80b871745d1b55da6](https://git.postgresql.org/pg/commitdiff/d6b8d29419df0efad57f95c80b871745d1b55da6)

- Improve documentation for default_tablespace on partitioned tables. Backpatch
  to 12, where 87259588d0ab introduced the current behavior.  Per note from
  Justin Pryzby.  Co-authored-by: Justin Pryzby <[email protected]>
  Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/94b9cb722552c37da78c8320bac1d5b55e34def6](https://git.postgresql.org/pg/commitdiff/94b9cb722552c37da78c8320bac1d5b55e34def6)

Fujii Masao pushed:

- Don't pass "ONLY" options specified in TRUNCATE to foreign data wrapper.
  Commit 8ff1c94649 allowed TRUNCATE command to truncate foreign tables.
  Previously the information about "ONLY" options specified in TRUNCATE command
  were passed to the foreign data wrapper. Then postgres_fdw constructed the
  TRUNCATE command to issue the remote server and included "ONLY" options in it
  based on the passed information.  On the other hand, "ONLY" options specified
  in SELECT, UPDATE or DELETE have no effect when accessing or modifying the
  remote table, i.e., are not passed to the foreign data wrapper. So it's
  inconsistent to make only TRUNCATE command pass the "ONLY" options to the
  foreign data wrapper. Therefore this commit changes the TRUNCATE command so
  that it doesn't pass the "ONLY" options to the foreign data wrapper, for the
  consistency with other statements. Also this commit changes postgres_fdw so
  that it always doesn't include "ONLY" options in the TRUNCATE command that it
  constructs.  Author: Fujii Masao Reviewed-by: Bharath Rupireddy, Kyotaro
  Horiguchi, Justin Pryzby, Zhihong Yu Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/8e9ea08bae93a754d5075b7bc9c0b2bc71958bfd](https://git.postgresql.org/pg/commitdiff/8e9ea08bae93a754d5075b7bc9c0b2bc71958bfd)

- doc: Review for "Allow TRUNCATE command to truncate foreign tables". Typos,
  corrections and language improvements in the docs.  Author: Justin Pryzby,
  Fujii Masao Reviewed-by: Bharath Rupireddy, Justin Pryzby, Fujii Masao
  Discussion:
  
[https://postgr.es/m/[email protected]](https://postgr.es/m/[email protected])
  
[https://git.postgresql.org/pg/commitdiff/0c8f40863acb94963df9fd6a4369eb71efe9a93b](https://git.postgresql.org/pg/commitdiff/0c8f40863acb94963df9fd6a4369eb71efe9a93b)

Andrew Dunstan pushed:

- Improve logic in PostgresVersion.pm. Handle the situation where perl swaps the
  order of operands of the comparison operator. See `perldoc overload` for
  details:  The third argument is set to TRUE if (and only if) the two operands
  have been swapped. Perl may do this to ensure that the first argument ($self)
  is an object implementing the overloaded operation, in line with general
  object calling conventions.
  
[https://git.postgresql.org/pg/commitdiff/fa26eba221a9e837493df47d0255ce615129e9a8](https://git.postgresql.org/pg/commitdiff/fa26eba221a9e837493df47d0255ce615129e9a8)

David Rowley pushed:

- Adjust EXPLAIN output for parallel Result Cache plans. Here we adjust the
  EXPLAIN ANALYZE output for Result Cache so that we don't show any Result Cache
  stats for parallel workers who don't contribute anything to Result Cache plan
  nodes.  I originally had ideas that workers who don't help could still have
  their Result Cache stats displayed.  The idea with that was so that I could
  write some parallel Result Cache regression tests that show the EXPLAIN
  ANALYZE output.  However, I realized a little too late that such tests would
  just not be possible to have run in a stable way on the buildfarm.  With that
  knowledge, before 9eacee2e6 went in, I had removed all of the tests that were
  showing the EXPLAIN ANALYZE output of a parallel Result Cache plan, however, I
  forgot to put back the code that adjusts the EXPLAIN output to hide the Result
  Cache stats for parallel workers who were not fast enough to help out before
  query execution was over. All other nodes behave this way and so should Result
  Cache.  Additionally, with this change, it now seems safe enough to remove the
  SET force_parallel_mode = off that I had added to the regression tests.  Also,
  perform some cleanup in the partition_prune tests. I had adjusted the
  explain_parallel_append() function to sanitize the Result Cache EXPLAIN
  ANALYZE output.  However, since I didn't actually include any parallel Result
  Cache tests that show their EXPLAIN ANALYZE output, that code does nothing and
  can be removed.  In passing, move the setting of memPeakKb into the scope
  where it's used.  Reported-by: Amit Khandekar Author: David Rowley, Amit
  Khandekar Discussion:
  
[https://postgr.es/m/caj3gd9d8skfy95gpm1zmsotx2-ogx5q-wlsf8f0ykeb0hcr...@mail.gmail.com](https://postgr.es/m/caj3gd9d8skfy95gpm1zmsotx2-ogx5q-wlsf8f0ykeb0hcr...@mail.gmail.com)
  
[https://git.postgresql.org/pg/commitdiff/3c80e96dffd4df7f66fffa5f265cbd87becb7ef5](https://git.postgresql.org/pg/commitdiff/3c80e96dffd4df7f66fffa5f265cbd87becb7ef5)

Bruce Momjian pushed:

- Revert use singular for -1 (commits 9ee7d533da and 5da9868ed9. Turns out you
  can specify negative values using plurals:
  
[https://english.stackexchange.com/questions/9735/is-1-followed-by-a-singular-or-plural-noun](https://english.stackexchange.com/questions/9735/is-1-followed-by-a-singular-or-plural-noun)
  so the previous code was correct enough, and consistent with other usage in
  our code.  Also add comment in the two places where this could be confused.
  Reported-by: Noah Misch  Diagnosed-by:
  [email protected]
  
[https://git.postgresql.org/pg/commitdiff/651d005e76bc0b9542615f609b4d0d946035dc58](https://git.postgresql.org/pg/commitdiff/651d005e76bc0b9542615f609b4d0d946035dc58)

# Pending Patches

Bharath Rupireddy sent in a patch to pass BLCKSZ instead of pageSize to
gistinitpage, bringing it into line with peers BloomInitPage, brin_page_init and
SpGistInitPage.

Yugo Nagata sent in two more revisions of a patch to implement incremental view
maintenance.

Peter Eisentraut sent in another revision of a patch to fix ALTER TABLE /
INHERIT with generated columns.

Tang sent in another revision of a patch to support tab completion with a query
result for uppercase character inputs in psql.

Tom Lane sent in a patch to remove some useless work being done in the rewriter.

Andrey V. Lepikhov sent in a patch to avoid unneeded work when not scanning
foreign partitions.

Masahiro Ikeda sent in another revision of a patch to speed up reporting wal
stats without introducing a new variable, and change the data type of XXXUsage
from long to int64.

Michaël Paquier sent in a patch to track authenticated identity in
pg_stat_activity, now that the capability is there for logging purposes.

Mark Dilger and Robert Haas traded patches to modify toast and test pg_amcheck
and modify toast corruption test expected output.

Vigneshwaran C and Bharath Rupireddy traded patches to enhanced error messages
to include hint messages for redundant options error.

Ajin Cherian sent in another revision of a patch to skip empty transactions for
logical replication.

Bharath Rupireddy sent in a patch to check for duplicate options and error out
in the CREATE COLLATION command.

Andrey V. Lepikhov sent in another revision of a patch to fix an infelicity
between the executor and async append nodes.

Andres Freund sent in a patch to fix a performance degradation of REFRESH
MATERIALIZED VIEW.

David Fetter and Aleksander Alekseev traded patches to ensure that tab
completion of ALTER TABLE ... VALIDATE CONSTRAINT ... only completes with
constraints that are not already valid.

Joel Jacobson and Michaël Paquier traded patches to ensure that
pg_identify_object_as_address() supports pg_event_trigger oids.

Vigneshwaran C, Masahiko Sawada, and Amit Kapila traded patches to fix the
computation of slot stats for 'total_bytes', which had a potential to count
things more than once, by using the size of the changes decoded for a
transaction to compute it.

Hou Zhijie sent in another revision of a patch to implement { CREATE | ALTER }
TABLE ... PARALLEL DML { UNSAFE | RESTRICTED | SAFE };

Kyotaro HORIGUCHI sent in another revision of a patch to fix some dubious error
messages and comments.

David Christensen sent in another revision of a patch to Expand the supported
units in pg_size_bytes to cover all units.

Tom Lane sent in a patch intended to fix a bug that manifested as pg_upgrade
fails to detect unsupported arrays and ranges by checking for uses of composite
types.

Hou Zhijie sent in another revision of a patch to fix some parallel safety
checks.

Peter Geoghegan sent in a patch intended to fix a bug that manifested as
"FailedAssertion" reported in lazy_scan_heap() when running logical replication
by setting all_visible_according_to_vm to false in lazy_scan_heap.

Amul Sul sent in a patch to hide the internal temp schema name in EXPLAIN, and
change the table descriptions for same.

Peter Smith sent in another revision of a patch to add support for prepared
transactions to built-in logical replication, and add prepare API support for
streaming transactions.

Vaibhav Dalvi sent in a patch to remove an unneeded post-increment in function
quote_identifier of pg_upgrade.

Richard Yen sent in three revisions of a patch to make it possible for
pg_filedump to read pg_filenode.map.

Vigneshwaran C sent in a patch to include xid in restoring reorder buffer
changes from disk.

Álvaro Herrera sent in another revision of a patch to fix a bug that manifested
as a race condition in InvalidateObsoleteReplicationSlots().

Peter Eisentraut sent in another revision of a patch to prevent lwlock dtrace
probes from unnecessary work.

Álvaro Herrera sent in another revision of a patch to remove a redundant
variable from transformCreateStmt.

Thomas Munro sent in a patch to add WL_SOCKET_CLOSED for socket shutdown events,
and use WL_SOCKET_CLOSED for client_connection_check_interval.

Amit Kapila sent in a patch to tighten the concurrent abort check during
decoding by covering cases that detecting ERRCODE_TRANSACTION_ROLLBACK does not.

Andres Freund sent in a patch to help make an upcoming WAL prefetch patch work.

David Rowley sent in another revision of a patch to use simplehash.h hashtables
in SMgr.

Justin Pryzby sent in another revision of a patch to add the changes needed to
allow testing upgrade to v14dev from v9.5-v13, add some more more changes needed
to allow upgrade testing, add a test to exercise binary compatibility, and  move
pg_upgrade kludges to an SQL script.

Julien Rouhaud sent in a patch to add a hook for extensible parsing.

Tom Lane sent in two revisions of a patch to fix a regex performance regression
induced by the new match-all code.

Vigneshwaran C sent in two more revisions of a patch to identify missing
publications from publisher during CREATE/ALTER SUBSCRIPTION.

Alexander Korotkov sent in four revisions of a patch to make
websearch_to_tsquery() parse text in quotes as a single token.

Noah Misch sent in another revision of a patch to dump public schema ownership
and security labels, and dump COMMENT ON SCHEMA public.

Reply via email to