diff options
author | Tom Lane <tgl@sss.pgh.pa.us> | 2025-08-10 16:31:54 -0400 |
---|---|---|
committer | Tom Lane <tgl@sss.pgh.pa.us> | 2025-08-10 16:31:54 -0400 |
commit | dfe189ecdf8709b332439ae72693d10b2640234b (patch) | |
tree | f26eeee92dde3c054c6301fcde00f526f44637fe /doc | |
parent | 70637d7ae0a20caffe88559a689a2a00cb1a1d2b (diff) |
Release notes for 17.6, 16.10, 15.14, 14.19, 13.22.
Diffstat (limited to 'doc')
-rw-r--r-- | doc/src/sgml/release-15.sgml | 1336 |
1 files changed, 1336 insertions, 0 deletions
diff --git a/doc/src/sgml/release-15.sgml b/doc/src/sgml/release-15.sgml index 18c5130a304..292b5f6b4f7 100644 --- a/doc/src/sgml/release-15.sgml +++ b/doc/src/sgml/release-15.sgml @@ -1,6 +1,1342 @@ <!-- doc/src/sgml/release-15.sgml --> <!-- See header comment in release.sgml about typical markup --> + <sect1 id="release-15-14"> + <title>Release 15.14</title> + + <formalpara> + <title>Release date:</title> + <para>2025-08-14</para> + </formalpara> + + <para> + This release contains a variety of fixes from 15.13. + For information about new features in major release 15, see + <xref linkend="release-15"/>. + </para> + + <sect2> + <title>Migration to Version 15.14</title> + + <para> + A dump/restore is not required for those running 15.X. + </para> + + <para> + However, if you have any + BRIN <literal>numeric_minmax_multi_ops</literal> indexes, it is + advisable to reindex them after updating. See the first changelog + entry below. + </para> + + <para> + Also, if you are upgrading from a version earlier than 15.13, + see <xref linkend="release-15-13"/>. + </para> + </sect2> + + <sect2> + <title>Changes</title> + + <itemizedlist> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master [80c758a2e] 2025-08-05 16:51:10 -0400 +Branch: REL_18_STABLE [9b681e239] 2025-08-05 16:51:10 -0400 +Branch: REL_17_STABLE [0b0d3c19b] 2025-08-05 16:51:10 -0400 +Branch: REL_16_STABLE [b9279058a] 2025-08-05 16:51:10 -0400 +Branch: REL_15_STABLE [835c9374d] 2025-08-05 16:51:10 -0400 +Branch: REL_14_STABLE [5b0c8e328] 2025-08-05 16:51:10 -0400 +--> + <para> + Fix incorrect distance calculation in + BRIN <literal>numeric_minmax_multi_ops</literal> support function + (Peter Eisentraut, Tom Lane) + <ulink url="&commit_baseurl;835c9374d">§</ulink> + </para> + + <para> + The results were sometimes wrong on 64-bit platforms, and wildly + wrong on 32-bit platforms. This did not produce obvious failures + because the logic is only used to choose how to merge values into + ranges; at worst the index would become inefficient and bloated. + Nonetheless it's recommended to reindex any BRIN indexes that use + the <literal>numeric_minmax_multi_ops</literal> operator class. + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master [71c0921b6] 2025-07-28 16:50:41 -0400 +Branch: REL_18_STABLE [637ead2e1] 2025-07-28 16:50:41 -0400 +Branch: REL_17_STABLE [fd4ad33fe] 2025-07-28 16:50:41 -0400 +Branch: REL_16_STABLE [6d5e493b4] 2025-07-28 16:50:42 -0400 +Branch: REL_15_STABLE [0ffbd345e] 2025-07-28 16:50:42 -0400 +Branch: REL_14_STABLE [0395464af] 2025-07-28 16:50:42 -0400 +Branch: REL_13_STABLE [589d6e640] 2025-07-28 16:50:42 -0400 +Branch: master [902f92221] 2025-07-29 12:47:38 -0400 +Branch: REL_18_STABLE [d5f014d89] 2025-07-29 12:47:19 -0400 +Branch: REL_17_STABLE [7571e0f6e] 2025-07-29 12:47:19 -0400 +Branch: REL_16_STABLE [762c6d8d2] 2025-07-29 12:47:19 -0400 +Branch: REL_15_STABLE [0928e18eb] 2025-07-29 12:47:20 -0400 +Branch: REL_14_STABLE [cdcdabce5] 2025-07-29 12:47:20 -0400 +Branch: REL_13_STABLE [0ae824704] 2025-07-29 12:47:20 -0400 +--> + <para> + Avoid regression in the size of XML input that we will accept + (Michael Paquier, Erik Wienhold) + <ulink url="&commit_baseurl;0ffbd345e">§</ulink> + <ulink url="&commit_baseurl;0928e18eb">§</ulink> + </para> + + <para> + Our workaround for a bug in early 2.13.x releases + of <application>libxml2</application> made use of a code path that + rejects text chunks exceeding 10MB, whereas the previous coding did + not. Those early releases are presumably extinct in the wild by + now, so revert to the previous coding. + </para> + </listitem> + + <listitem> +<!-- +Author: Dean Rasheed <dean.a.rasheed@gmail.com> +Branch: master Release: REL_18_BR [b006bcd53] 2025-05-31 12:12:58 +0100 +Branch: REL_17_STABLE [ab52f6b5b] 2025-05-31 12:17:30 +0100 +Branch: REL_16_STABLE [3611794af] 2025-05-31 12:19:37 +0100 +Branch: REL_15_STABLE [d6a3f3272] 2025-05-31 12:21:02 +0100 +--> + <para> + Fix <command>MERGE</command> into a plain-inheritance parent table + (Dean Rasheed) + <ulink url="&commit_baseurl;d6a3f3272">§</ulink> + </para> + + <para> + Insertions into such a target table could crash or produce incorrect + query results due to failing to handle <literal>WITH CHECK + OPTION</literal> and <literal>RETURNING</literal> actions. + </para> + </listitem> + + <listitem> +<!-- +Author: Etsuro Fujita <efujita@postgresql.org> +Branch: master [9e63f83a7] 2025-08-08 17:35:00 +0900 +Branch: REL_18_STABLE [bba6a6faf] 2025-08-08 17:35:00 +0900 +Branch: REL_17_STABLE [e028ce911] 2025-08-08 17:35:01 +0900 +Branch: REL_16_STABLE [3863c6fb6] 2025-08-08 17:35:02 +0900 +Branch: REL_15_STABLE [f39a7f32a] 2025-08-08 17:35:02 +0900 +Branch: REL_14_STABLE [73eb6afa1] 2025-08-08 17:35:03 +0900 +Branch: REL_13_STABLE [afdb4cde1] 2025-08-08 17:35:04 +0900 +--> + <para> + Allow tables with statement-level triggers to become partitions or + inheritance children (Etsuro Fujita) + <ulink url="&commit_baseurl;f39a7f32a">§</ulink> + </para> + + <para> + We do not allow partitions or inheritance child tables to have + row-level triggers with transition tables, because an operation on + the whole inheritance tree would need to maintain a separate + transition table for each such child table. But that problem does + not apply for statement-level triggers, because only the parent's + statement-level triggers will be fired. The code that checks + whether an existing table can become a partition or inheritance + child nonetheless rejected both kinds of trigger. + </para> + </listitem> + + <listitem> +<!-- +Author: Etsuro Fujita <efujita@postgresql.org> +Branch: master [62a1211d3] 2025-08-08 10:50:00 +0900 +Branch: REL_18_STABLE [ce8817022] 2025-08-08 10:50:01 +0900 +Branch: REL_17_STABLE [9048a83c7] 2025-08-08 10:50:02 +0900 +Branch: REL_16_STABLE [9cca445df] 2025-08-08 10:50:02 +0900 +Branch: REL_15_STABLE [d642d2306] 2025-08-08 10:50:03 +0900 +Branch: REL_14_STABLE [e94fc1a8a] 2025-08-08 10:50:04 +0900 +Branch: REL_13_STABLE [b6641f7b0] 2025-08-08 10:50:05 +0900 +--> + <para> + Disallow collecting transition tuples from child foreign tables + (Etsuro Fujita) + <ulink url="&commit_baseurl;d642d2306">§</ulink> + </para> + + <para> + We do not support triggers with transition tables on foreign tables. + However, the case of a partition or inheritance child that is a + foreign table was overlooked. If the parent has such a trigger, + incorrect transition tuples were collected from the foreign child. + Instead throw an error, reporting that the case is not supported. + </para> + </listitem> + + <listitem> +<!-- +Author: Nathan Bossart <nathan@postgresql.org> +Branch: master [9eb6068fb] 2025-08-01 16:52:11 -0500 +Branch: REL_18_STABLE [7b9674a8b] 2025-08-01 16:52:11 -0500 +Branch: REL_17_STABLE [39ff05636] 2025-08-01 16:52:11 -0500 +Branch: REL_16_STABLE [b998ce327] 2025-08-01 16:52:11 -0500 +Branch: REL_15_STABLE [f79ca73d7] 2025-08-01 16:52:11 -0500 +--> + <para> + Allow resetting unknown custom parameters with reserved prefixes + (Nathan Bossart) + <ulink url="&commit_baseurl;f79ca73d7">§</ulink> + </para> + + <para> + Previously, if a parameter setting had been stored + using <command>ALTER DATABASE/ROLE/SYSTEM</command>, the stored + setting could not be removed if the parameter was unknown but had a + reserved prefix. This case could arise if an extension used to have + a parameter, but that parameter had been removed in an upgrade. + </para> + </listitem> + + <listitem> +<!-- +Author: Amit Kapila <akapila@postgresql.org> +Branch: master [2ab2d6f97] 2025-08-01 07:58:48 +0000 +Branch: REL_18_STABLE [d9f01a287] 2025-08-01 07:46:22 +0000 +Branch: REL_17_STABLE [8c298324a] 2025-08-01 06:53:16 +0000 +Branch: REL_16_STABLE [adfd80219] 2025-08-01 06:40:06 +0000 +Branch: REL_15_STABLE [434d2d147] 2025-08-01 07:23:37 +0000 +Branch: REL_14_STABLE [41fb3f51c] 2025-08-01 07:16:30 +0000 +--> + <para> + Fix a potential deadlock during <command>ALTER SUBSCRIPTION ... DROP + PUBLICATION</command> (Ajin Cherian) + <ulink url="&commit_baseurl;434d2d147">§</ulink> + </para> + + <para> + Ensure that server processes acquire catalog locks in a consistent + order during replication origin drops. + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master Release: REL_18_BR [5861b1f34] 2025-06-20 13:41:11 -0400 +Branch: REL_17_STABLE [fdd826922] 2025-06-20 13:41:11 -0400 +Branch: REL_16_STABLE [1e24ea160] 2025-06-20 13:41:11 -0400 +Branch: REL_15_STABLE [75b8982ea] 2025-06-20 13:41:11 -0400 +Branch: REL_14_STABLE [27af8b9be] 2025-06-20 13:41:11 -0400 +Branch: REL_13_STABLE [4b66cb188] 2025-06-20 13:41:11 -0400 +--> + <para> + Shorten the race condition window for creating indexes with + conflicting names (Tom Lane) + <ulink url="&commit_baseurl;75b8982ea">§</ulink> + </para> + + <para> + When choosing an auto-generated name for an index, avoid conflicting + with not-yet-committed <structname>pg_class</structname> rows as + well as fully-valid ones. This avoids possibly choosing the same + name as some concurrent <command>CREATE INDEX</command> did, + when that command is still in process of filling its index, or is + done but is part of a not-yet-committed transaction. There's still + a window for trouble, but it's only as long as the time needed to + validate a new index's parameters and insert + its <structname>pg_class</structname> row. + </para> + </listitem> + + <listitem> +<!-- +Author: Michael Paquier <michael@paquier.xyz> +Branch: master Release: REL_18_BR [661643ded] 2025-06-25 10:03:46 +0900 +Branch: REL_17_STABLE [2e0b5d252] 2025-06-25 10:03:50 +0900 +Branch: REL_16_STABLE [d187cabdd] 2025-06-25 10:03:52 +0900 +Branch: REL_15_STABLE [354944663] 2025-06-25 10:03:53 +0900 +Branch: REL_14_STABLE [c079ba3fc] 2025-06-25 10:03:54 +0900 +Branch: REL_13_STABLE [65c3223f9] 2025-06-25 10:03:56 +0900 +--> + <para> + Prevent usage of incorrect <command>VACUUM</command> options in some + cases where multiple tables are vacuumed in a single command (Nathan + Bossart, Michael Paquier) + <ulink url="&commit_baseurl;354944663">§</ulink> + </para> + + <para> + The <literal>TRUNCATE</literal> and <literal>INDEX_CLEANUP</literal> + options of one table could be applied to others. + </para> + </listitem> + + <listitem> +<!-- +Author: Michael Paquier <michael@paquier.xyz> +Branch: master Release: REL_18_BR [d46911e58] 2025-05-28 08:58:40 +0900 +Branch: REL_17_STABLE [e3ffc3e91] 2025-05-28 08:59:22 +0900 +Branch: REL_16_STABLE [e9e535d61] 2025-05-28 08:59:24 +0900 +Branch: REL_15_STABLE [b3e99115e] 2025-05-28 08:59:25 +0900 +Branch: REL_14_STABLE [1fe15d25e] 2025-05-28 08:59:27 +0900 +Branch: REL_13_STABLE [9481d1614] 2025-05-28 08:59:28 +0900 +Branch: master Release: REL_18_BR [4fbb46f61] 2025-05-28 09:43:31 +0900 +Branch: REL_17_STABLE [a3c6d92f3] 2025-05-28 09:43:45 +0900 +Branch: REL_16_STABLE [52d08620e] 2025-05-28 09:43:46 +0900 +Branch: REL_15_STABLE [4dc642e75] 2025-05-28 09:43:48 +0900 +Branch: REL_14_STABLE [0c09922c0] 2025-05-28 09:43:50 +0900 +Branch: REL_13_STABLE [31ee5ec69] 2025-05-28 09:43:51 +0900 +--> + <para> + Fix processing of character classes within <literal>SIMILAR + TO</literal> regular expressions (Laurenz Albe) + <ulink url="&commit_baseurl;b3e99115e">§</ulink> + <ulink url="&commit_baseurl;4dc642e75">§</ulink> + </para> + + <para> + The code that translates <literal>SIMILAR TO</literal> pattern + matching expressions to POSIX-style regular expressions did not + consider that square brackets can be nested. For example, in a + pattern like <literal>[[:alpha:]%_]</literal>, the code treated + the <literal>%</literal> and <literal>_</literal> characters as + metacharacters when they should be literals. + </para> + </listitem> + + <listitem> +<!-- +Author: Heikki Linnakangas <heikki.linnakangas@iki.fi> +Branch: master Release: REL_18_BR [29f7ce6fe] 2025-05-19 18:50:26 +0300 +Branch: REL_17_STABLE [54c05292b] 2025-05-19 18:50:47 +0300 +Branch: REL_16_STABLE [92a9ba3b9] 2025-05-19 18:50:50 +0300 +Branch: REL_15_STABLE [72fe74ca5] 2025-05-19 18:50:52 +0300 +Branch: REL_14_STABLE [0420b24fe] 2025-05-19 18:50:54 +0300 +Branch: REL_13_STABLE [7ee00918f] 2025-05-19 18:49:34 +0300 +Branch: master Release: REL_18_BR [cbf53e2b8] 2025-05-20 10:39:14 +0300 +Branch: REL_17_STABLE [a4da7b0cf] 2025-05-20 10:41:20 +0300 +Branch: REL_16_STABLE [558ea446a] 2025-05-20 10:41:50 +0300 +--> + <para> + When deparsing queries, always add parentheses around the expression + in <literal>FETCH FIRST <replaceable>expression</replaceable> ROWS + WITH TIES</literal> clauses (Heikki Linnakangas) + <ulink url="&commit_baseurl;72fe74ca5">§</ulink> + </para> + + <para> + This avoids some cases where the deparsed result wasn't + syntactically valid. + </para> + </listitem> + + <listitem> +<!-- +Author: Alexander Korotkov <akorotkov@postgresql.org> +Branch: REL_18_STABLE [bae507821] 2025-07-27 15:10:02 +0300 +Branch: REL_17_STABLE [13559de95] 2025-07-27 15:10:24 +0300 +Branch: REL_16_STABLE [f0cdc2afd] 2025-07-27 15:10:29 +0300 +Branch: REL_15_STABLE [b248a3ba4] 2025-07-27 15:10:29 +0300 +Branch: REL_14_STABLE [50026136c] 2025-07-27 15:10:31 +0300 +Branch: REL_13_STABLE [f32a47161] 2025-07-27 15:10:32 +0300 +Branch: master [466c5435f] 2025-08-07 14:29:02 +0300 +Branch: REL_18_STABLE [5cfbff48a] 2025-08-07 14:31:18 +0300 +Branch: REL_17_STABLE [605890034] 2025-08-07 14:59:54 +0300 +Branch: REL_16_STABLE [2ac50f118] 2025-08-07 14:31:23 +0300 +Branch: REL_15_STABLE [73f897ba5] 2025-08-07 14:31:24 +0300 +Branch: REL_14_STABLE [c5d66fc12] 2025-08-07 14:31:25 +0300 +Branch: REL_13_STABLE [7f872ae70] 2025-08-07 14:31:26 +0300 +--> + <para> + Limit the checkpointer process's fsync request queue size (Alexander + Korotkov, Xuneng Zhou) + <ulink url="&commit_baseurl;b248a3ba4">§</ulink> + <ulink url="&commit_baseurl;73f897ba5">§</ulink> + </para> + + <para> + With very large <varname>shared_buffers</varname> settings, it was + possible for the checkpointer to attempt to allocate more than 1GB + for fsync requests, leading to failure and an infinite loop. Clamp + the queue size to prevent this scenario. + </para> + </listitem> + + <listitem> +<!-- +Author: Alexander Korotkov <akorotkov@postgresql.org> +Branch: master [d3917d8f1] 2025-07-19 13:45:51 +0300 +Branch: REL_18_STABLE [5449d5b7a] 2025-07-19 13:44:30 +0300 +Branch: REL_17_STABLE [c9f4e7520] 2025-07-20 01:29:14 +0300 +Branch: REL_16_STABLE [b485e1c89] 2025-07-19 13:46:02 +0300 +Branch: REL_15_STABLE [9f270f48f] 2025-07-19 13:46:03 +0300 +Branch: REL_14_STABLE [bedfdb85b] 2025-07-19 14:13:41 +0300 +Branch: REL_13_STABLE [762f352ca] 2025-07-19 14:13:58 +0300 +--> + <para> + Avoid infinite wait in logical decoding when reading a + partially-written WAL record (Vignesh C) + <ulink url="&commit_baseurl;9f270f48f">§</ulink> + </para> + + <para> + If the server crashes after writing the first part of a WAL record + that would span multiple pages, subsequent logical decoding of the + WAL stream would wait for data to arrive on the next WAL page. + That might never happen if the server is now idle. + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master [64840e462] 2025-07-11 18:50:13 -0400 +Branch: REL_18_STABLE [ccacaf4fa] 2025-07-11 18:50:13 -0400 +Branch: REL_17_STABLE [50959f96e] 2025-07-11 18:50:13 -0400 +Branch: REL_16_STABLE [53a936b61] 2025-07-11 18:50:13 -0400 +Branch: REL_15_STABLE [de73cb3ed] 2025-07-11 18:50:13 -0400 +Branch: REL_14_STABLE [ac8cdb249] 2025-07-11 18:50:13 -0400 +Branch: REL_13_STABLE [093d3d745] 2025-07-11 18:50:13 -0400 +--> + <para> + Fix inconsistent quoting of role names in ACL strings (Tom Lane) + <ulink url="&commit_baseurl;de73cb3ed">§</ulink> + </para> + + <para> + The previous quoting rule was locale-sensitive, which could lead to + portability problems when transferring <type>aclitem</type> values + across installations. (<application>pg_dump</application> does not + do that, but other tools might.) To ensure consistency, always quote + non-ASCII characters in <type>aclitem</type> output; but to preserve + backward compatibility, never require that they be quoted + during <type>aclitem</type> input. + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master Release: REL_18_BR [aa87f69c0] 2025-06-02 15:22:44 -0400 +Branch: REL_17_STABLE [d4046125d] 2025-06-02 15:22:44 -0400 +Branch: REL_16_STABLE [ab758ec4d] 2025-06-02 15:22:44 -0400 +Branch: REL_15_STABLE [e76097124] 2025-06-02 15:22:44 -0400 +Branch: REL_14_STABLE [eb4234647] 2025-06-02 15:22:45 -0400 +Branch: REL_13_STABLE [cd31eaaeb] 2025-06-02 15:22:45 -0400 +--> + <para> + Reject equal signs (<literal>=</literal>) in the names of relation + options and foreign-data options (Tom Lane) + <ulink url="&commit_baseurl;e76097124">§</ulink> + </para> + + <para> + There's no evident use-case for option names like this, and allowing + them creates ambiguity in the stored representation. + </para> + </listitem> + + <listitem> +<!-- +Author: Michael Paquier <michael@paquier.xyz> +Branch: master [3369a3b49] 2025-07-02 13:48:36 +0900 +Branch: REL_18_STABLE [d09d13793] 2025-07-02 13:48:41 +0900 +Branch: REL_17_STABLE [074003431] 2025-07-02 13:48:43 +0900 +Branch: REL_16_STABLE [5c639523f] 2025-07-02 13:48:45 +0900 +Branch: REL_15_STABLE [d44efe87e] 2025-07-02 13:48:48 +0900 +--> + <para> + Fix potentially-incorrect decompression of LZ4-compressed archive + data (Mikhail Gribkov) + <ulink url="&commit_baseurl;d44efe87e">§</ulink> + </para> + + <para> + This error seems to manifest only with not-very-compressible input + data, which may explain why it escaped detection. + </para> + </listitem> + + <listitem> +<!-- +Author: Peter Geoghegan <pg@bowt.ie> +Branch: master Release: REL_18_BR [7c319f549] 2025-06-11 09:17:35 -0400 +Branch: REL_17_STABLE [40aa5ddea] 2025-06-11 09:17:33 -0400 +Branch: REL_16_STABLE [c7f25feb3] 2025-06-11 09:17:31 -0400 +Branch: REL_15_STABLE [d2ec67109] 2025-06-11 09:17:29 -0400 +Branch: REL_14_STABLE [7c7c0a77d] 2025-06-11 09:17:27 -0400 +Branch: REL_13_STABLE [38c8d2987] 2025-06-11 09:17:25 -0400 +--> + <para> + Avoid a rare scenario where a btree index scan could mark the wrong + index entries as dead (Peter Geoghegan) + <ulink url="&commit_baseurl;d2ec67109">§</ulink> + </para> + </listitem> + + <listitem> +<!-- +Author: Masahiko Sawada <msawada@postgresql.org> +Branch: master Release: REL_18_BR [d87d07b7a] 2025-06-16 17:36:01 -0700 +Branch: REL_17_STABLE [45c357e0e] 2025-06-16 17:35:58 -0700 +Branch: REL_16_STABLE [b2ae07720] 2025-06-16 17:35:55 -0700 +Branch: REL_15_STABLE [fc0fb77c5] 2025-06-16 17:35:53 -0700 +Branch: REL_14_STABLE [983b36362] 2025-06-16 17:35:50 -0700 +Branch: REL_13_STABLE [1230be12f] 2025-06-16 17:35:48 -0700 +Branch: REL_13_STABLE [87819f766] 2025-06-24 07:07:40 -0700 +--> + <para> + Avoid re-distributing cache invalidation messages from other + transactions during logical replication (vignesh C) + <ulink url="&commit_baseurl;fc0fb77c5">§</ulink> + </para> + + <para> + Our previous round of minor releases included a bug fix to ensure + that replication receiver processes would respond to cross-process + cache invalidation messages, preventing them from using stale + catalog data while performing replication updates. However, the fix + unintentionally made them also redistribute those messages again, + leading to an exponential increase in the number of invalidation + messages, which would often end in a memory allocation failure. + Fix by not redistributing received messages. + </para> + </listitem> + + <listitem> +<!-- +Author: Alexander Korotkov <akorotkov@postgresql.org> +Branch: REL_17_STABLE [2090edc6f] 2025-06-14 03:52:45 +0300 +Branch: REL_16_STABLE [cea8f2c3e] 2025-06-14 03:53:18 +0300 +Branch: REL_15_STABLE [dd9bc1a17] 2025-06-14 04:15:04 +0300 +Branch: REL_14_STABLE [e2832bd96] 2025-06-14 04:15:24 +0300 +Branch: REL_13_STABLE [dd3df0b85] 2025-06-14 04:15:29 +0300 +--> + <para> + Avoid premature removal of old WAL during checkpoints (Vitaly Davydov) + <ulink url="&commit_baseurl;dd9bc1a17">§</ulink> + </para> + + <para> + If a replication slot's restart point is advanced while a checkpoint + is in progress, no-longer-needed WAL segments could get removed too + soon, leading to recovery failure if the database crashes + immediately afterwards. Fix by keeping them for one additional + checkpoint cycle. + </para> + </listitem> + + <listitem> +<!-- +Author: Amit Kapila <akapila@postgresql.org> +Branch: master Release: REL_18_BR [ad5eaf390] 2025-05-19 12:13:06 +0530 +Branch: REL_17_STABLE [7318f241d] 2025-05-19 11:55:55 +0530 +Branch: REL_16_STABLE [c0f51fde5] 2025-05-19 11:41:22 +0530 +Branch: REL_15_STABLE [9d1a62359] 2025-05-19 11:28:19 +0530 +Branch: REL_14_STABLE [e68459489] 2025-05-19 11:15:09 +0530 +Branch: REL_13_STABLE [e323d9df0] 2025-05-19 11:04:39 +0530 +--> + <para> + Never move a replication slot's confirmed-flush position backwards + (Shveta Malik) + <ulink url="&commit_baseurl;9d1a62359">§</ulink> + </para> + + <para> + In some cases a replication client could acknowledge an LSN that's + past what it has stored persistently, and then perhaps send an older + LSN after a restart. We consider this not-a-bug so long as the + client did not have anything it needed to do for the WAL between the + two points. However, we should not re-send that WAL for fear of + data duplication, so make sure we always believe the latest + confirmed LSN for a given slot. + </para> + </listitem> + + <listitem> +<!-- +Author: Fujii Masao <fujii@postgresql.org> +Branch: master Release: REL_18_BR [961553daf] 2025-05-31 00:08:40 +0900 +Branch: REL_17_STABLE [24c5ad5be] 2025-05-31 00:14:07 +0900 +Branch: REL_16_STABLE [63fa7caa9] 2025-05-31 00:14:14 +0900 +Branch: REL_15_STABLE [405cca9da] 2025-05-31 00:14:22 +0900 +Branch: REL_14_STABLE [9130d8eee] 2025-05-31 00:14:29 +0900 +Branch: REL_13_STABLE [706344f06] 2025-05-31 00:14:35 +0900 +--> + <para> + Allow waiting for a transaction on a standby server to be + interrupted (Kevin K Biju) + <ulink url="&commit_baseurl;405cca9da">§</ulink> + </para> + + <para> + Creation of a replication slot on a standby server may require waiting + for some active transaction(s) to finish on the primary and then be + replayed on the standby. Since that could be an indefinite wait, + it's desirable to allow the operation to be cancelled, but there was + no check for query cancel in the loop. + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master Release: REL_18_BR [02502c1bc] 2025-05-23 14:43:43 -0400 +Branch: REL_17_STABLE [cd3064f98] 2025-05-23 14:43:43 -0400 +Branch: REL_16_STABLE [e087b5b79] 2025-05-23 14:43:44 -0400 +Branch: REL_15_STABLE [13d21b48a] 2025-05-23 14:43:44 -0400 +--> + <para> + Fix per-relation memory leakage in autovacuum (Tom Lane) + <ulink url="&commit_baseurl;13d21b48a">§</ulink> + </para> + </listitem> + + <listitem> +<!-- +Author: Nathan Bossart <nathan@postgresql.org> +Branch: master Release: REL_18_BR [706054b11] 2025-05-30 15:17:28 -0500 +Branch: REL_17_STABLE [fe8ea7a2a] 2025-05-30 15:17:28 -0500 +Branch: REL_16_STABLE [24135398f] 2025-05-30 15:17:28 -0500 +Branch: REL_15_STABLE [ddfcfb7ce] 2025-05-30 15:17:28 -0500 +Branch: REL_14_STABLE [b65be6ef0] 2025-05-30 15:17:28 -0500 +Branch: REL_13_STABLE [b7ba2c030] 2025-05-30 15:17:28 -0500 +--> + <para> + Fix some places that might try to fetch toasted fields of system + catalogs without any snapshot (Nathan Bossart) + <ulink url="&commit_baseurl;ddfcfb7ce">§</ulink> + </para> + + <para> + This could result in an assertion failure or <quote>cannot fetch + toast data without an active snapshot</quote> error. + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master Release: REL_18_BR [8319e5cb5] 2025-06-29 13:56:03 -0400 +Branch: REL_17_STABLE [bbfcbc4cd] 2025-06-29 13:56:03 -0400 +Branch: REL_16_STABLE [c15798cf9] 2025-06-29 13:56:03 -0400 +Branch: REL_15_STABLE [614ffb26d] 2025-06-29 13:56:03 -0400 +Branch: REL_14_STABLE [25cab4473] 2025-06-29 13:56:03 -0400 +Branch: REL_13_STABLE [13f1e9f26] 2025-06-29 13:56:03 -0400 +Branch: master [a10f21e6c] 2025-07-03 13:46:07 -0400 +Branch: REL_18_STABLE [3d7a96871] 2025-07-03 13:46:07 -0400 +Branch: REL_17_STABLE [6d4395b40] 2025-07-03 13:46:07 -0400 +Branch: REL_16_STABLE [d36980b71] 2025-07-03 13:46:07 -0400 +Branch: REL_15_STABLE [e6dd6e6ee] 2025-07-03 13:46:07 -0400 +Branch: REL_14_STABLE [e902f8181] 2025-07-03 13:46:07 -0400 +Branch: REL_13_STABLE [f9ba071cc] 2025-07-03 13:46:07 -0400 +--> + <para> + Avoid assertion failure during cross-table constraint updates + (Tom Lane, Jian He) + <ulink url="&commit_baseurl;614ffb26d">§</ulink> + <ulink url="&commit_baseurl;e6dd6e6ee">§</ulink> + </para> + </listitem> + + <listitem> +<!-- +Author: Álvaro Herrera <alvherre@kurilemu.de> +Branch: master [b8926a5b4] 2025-07-17 17:40:22 +0200 +Branch: REL_18_STABLE [e0d3f3cfb] 2025-07-17 17:40:22 +0200 +Branch: REL_17_STABLE [0c466f5e0] 2025-07-17 17:40:22 +0200 +Branch: REL_16_STABLE [4871c1e9c] 2025-07-17 17:40:22 +0200 +Branch: REL_15_STABLE [c2720ac60] 2025-07-17 17:40:22 +0200 +Branch: REL_14_STABLE [b9a896828] 2025-07-17 17:40:22 +0200 +Branch: REL_13_STABLE [43cd85962] 2025-07-17 17:40:22 +0200 +--> + <para> + Remove faulty assertion that a command tag must have been determined + by the end of <function>PortalRunMulti()</function> (Álvaro Herrera) + <ulink url="&commit_baseurl;c2720ac60">§</ulink> + </para> + + <para> + This failed in edge cases such as an empty prepared statement. + </para> + </listitem> + + <listitem> +<!-- +Author: Richard Guo <rguo@postgresql.org> +Branch: master Release: REL_18_BR [fe29b2a1d] 2025-05-15 17:09:04 +0900 +Branch: REL_17_STABLE [2f48b4f07] 2025-05-15 17:10:45 +0900 +Branch: REL_16_STABLE [d3716d4b1] 2025-05-15 17:21:15 +0900 +Branch: REL_15_STABLE [666103090] 2025-05-15 17:26:13 +0900 +--> + <para> + Fix assertion failure in <literal>XMLTABLE</literal> parsing + (Richard Guo) + <ulink url="&commit_baseurl;666103090">§</ulink> + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master [87b05fdc7] 2025-07-07 14:33:20 -0400 +Branch: REL_18_STABLE [440c5ee20] 2025-07-07 14:33:34 -0400 +Branch: REL_17_STABLE [a553a2289] 2025-07-07 14:33:47 -0400 +Branch: REL_16_STABLE [3bbc1c4a7] 2025-07-07 14:33:56 -0400 +Branch: REL_15_STABLE [c65c36ab5] 2025-07-07 14:34:04 -0400 +Branch: REL_14_STABLE [602c91cf2] 2025-07-07 14:34:12 -0400 +Branch: REL_13_STABLE [ae693c0bf] 2025-07-07 14:34:19 -0400 +--> + <para> + Restore the ability to run PL/pgSQL expressions in parallel + (Dipesh Dhameliya) + <ulink url="&commit_baseurl;c65c36ab5">§</ulink> + </para> + + <para> + PL/pgSQL's notion of an <quote>expression</quote> is very broad, + encompassing any SQL <command>SELECT</command> query that returns a + single column and no more than one row. So there are cases, for + example evaluation of an aggregate function, where the query + involves significant work and it'd be useful to run it with parallel + workers. This used to be possible, but a previous bug fix + unintentionally disabled it. + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master Release: REL_18_BR [c6f7f11d8] 2025-06-01 14:48:35 -0400 +Branch: REL_17_STABLE [7559a16e2] 2025-06-01 14:48:35 -0400 +Branch: REL_16_STABLE [5c7fd5976] 2025-06-01 14:48:35 -0400 +Branch: REL_15_STABLE [b56a92651] 2025-06-01 14:48:35 -0400 +Branch: REL_14_STABLE [31a3a15fa] 2025-06-01 14:48:35 -0400 +Branch: REL_13_STABLE [1c78d5553] 2025-06-01 14:48:35 -0400 +Branch: master Release: REL_18_BR [4672b6223] 2025-06-01 14:55:24 -0400 +Branch: REL_17_STABLE [6f724fcf8] 2025-06-01 14:55:24 -0400 +Branch: REL_16_STABLE [ecc8fd2b7] 2025-06-01 14:55:24 -0400 +Branch: REL_15_STABLE [b898bb2a7] 2025-06-01 14:55:24 -0400 +Branch: REL_14_STABLE [d4556f592] 2025-06-01 14:55:24 -0400 +Branch: REL_13_STABLE [93aca1246] 2025-06-01 14:55:24 -0400 +--> + <para> + Fix edge-case resource leaks in PL/Python error reporting (Tom Lane) + <ulink url="&commit_baseurl;b56a92651">§</ulink> + <ulink url="&commit_baseurl;b898bb2a7">§</ulink> + </para> + + <para> + An out-of-memory failure while reporting an error from Python could + result in failure to drop reference counts on Python objects, + leading to session-lifespan memory leakage. + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master [daf9bdc47] 2025-07-17 12:46:57 -0400 +Branch: REL_18_STABLE [bfa9b25c9] 2025-07-17 12:46:57 -0400 +Branch: REL_17_STABLE [3f10d2b66] 2025-07-17 12:46:58 -0400 +Branch: REL_16_STABLE [009c20a3d] 2025-07-17 12:46:58 -0400 +Branch: REL_15_STABLE [a372a64db] 2025-07-17 12:46:58 -0400 +Branch: REL_14_STABLE [d5cba7746] 2025-07-17 12:46:59 -0400 +Branch: REL_13_STABLE [9dcd1aa81] 2025-07-17 12:46:59 -0400 +--> + <para> + Fix <application>libpq</application>'s <function>PQport()</function> + function to never return NULL unless the passed connection is NULL + (Daniele Varrazzo) + <ulink url="&commit_baseurl;a372a64db">§</ulink> + </para> + + <para> + This is the documented behavior, but + recent <application>libpq</application> versions would return NULL + in some cases where the user had not provided a port specification. + Revert to our historical behavior of returning an empty string in + such cases. (v18 and later will return the compiled-in default port + number, typically <literal>"5432"</literal>, instead.) + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master Release: REL_18_BR [d98cefe11] 2025-05-30 12:55:15 -0400 +Branch: REL_17_STABLE [8b0aa7a6b] 2025-05-30 12:55:15 -0400 +Branch: REL_16_STABLE [ca70ee6ed] 2025-05-30 12:55:15 -0400 +Branch: REL_15_STABLE [39b1d1907] 2025-05-30 12:55:15 -0400 +Branch: REL_14_STABLE [a7da7914c] 2025-05-30 12:55:15 -0400 +Branch: REL_13_STABLE [c81cdffa1] 2025-05-30 12:55:15 -0400 +--> + <para> + Avoid failure when GSSAPI authentication requires packets larger + than 16kB (Jacob Champion, Tom Lane) + <ulink url="&commit_baseurl;39b1d1907">§</ulink> + </para> + + <para> + Larger authentication packets are needed for Active Directory users + who belong to many AD groups. This limitation manifested in + connection failures with unintelligible error messages, + typically <quote>GSSAPI context establishment error: The routine + must be called again to complete its function: Unknown + error</quote>. + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master Release: REL_18_BR [137935bd1] 2025-06-10 18:39:34 -0400 +Branch: REL_17_STABLE [30e0d9ee9] 2025-06-10 18:39:34 -0400 +Branch: REL_16_STABLE [3f37400cf] 2025-06-10 18:39:34 -0400 +Branch: REL_15_STABLE [6a4d93eda] 2025-06-10 18:39:34 -0400 +Branch: REL_14_STABLE [0703c9385] 2025-06-10 18:39:34 -0400 +Branch: REL_13_STABLE [f09fea386] 2025-06-10 18:39:34 -0400 +--> + <para> + Fix timing-dependent failures in SSL and GSSAPI data transmission + (Tom Lane) + <ulink url="&commit_baseurl;6a4d93eda">§</ulink> + </para> + + <para> + When using SSL or GSSAPI encryption in non-blocking + mode, <application>libpq</application> sometimes failed + with <quote>SSL error: bad length</quote> or <quote>GSSAPI caller + failed to retransmit all data needing to be retried</quote>. + </para> + </listitem> + + <listitem> +<!-- +Author: Michael Paquier <michael@paquier.xyz> +Branch: master [1b8bbee05] 2025-07-22 14:00:00 +0900 +Branch: REL_18_STABLE [0ded7615d] 2025-07-22 14:00:04 +0900 +Branch: REL_17_STABLE [2805e1c1e] 2025-07-22 14:00:05 +0900 +Branch: REL_16_STABLE [313d3102f] 2025-07-22 14:00:07 +0900 +Branch: REL_15_STABLE [0123922f8] 2025-07-22 14:00:08 +0900 +Branch: REL_14_STABLE [408fe659a] 2025-07-22 14:00:10 +0900 +Branch: REL_13_STABLE [c934d5673] 2025-07-22 14:00:12 +0900 +--> + <para> + Avoid null-pointer dereference during connection lookup + in <application>ecpg</application> applications (Aleksander + Alekseev) + <ulink url="&commit_baseurl;0123922f8">§</ulink> + </para> + + <para> + The case could occur only if the application has some connections + that are named and some that are not. + </para> + </listitem> + + <listitem> +<!-- +Author: Masahiko Sawada <msawada@postgresql.org> +Branch: master [f5a987c0e] 2025-07-09 05:45:34 -0700 +Branch: REL_18_STABLE [765a4c94c] 2025-07-09 05:45:31 -0700 +Branch: REL_17_STABLE [c1c6169eb] 2025-07-09 05:45:28 -0700 +Branch: REL_16_STABLE [d69836b13] 2025-07-09 05:45:26 -0700 +Branch: REL_15_STABLE [e3584e457] 2025-07-09 05:45:23 -0700 +Branch: REL_14_STABLE [0514616f0] 2025-07-09 05:45:20 -0700 +--> + <para> + Improve <application>psql</application>'s tab completion + for <command>COPY</command> and <command>\copy</command> options + (Atsushi Torikoshi) + <ulink url="&commit_baseurl;e3584e457">§</ulink> + </para> + + <para> + The same completions were offered for both <command>COPY + FROM</command> and <command>COPY TO</command>, although some options + are only valid for one case or the other. Distinguish these cases + to provide more accurate suggestions. + </para> + </listitem> + + <listitem> +<!-- +Author: Fujii Masao <fujii@postgresql.org> +Branch: master [12efa4897] 2025-08-03 10:49:03 +0900 +Branch: REL_18_STABLE [fee46ab4f] 2025-08-03 10:49:54 +0900 +Branch: REL_17_STABLE [398e07162] 2025-08-03 10:50:01 +0900 +Branch: REL_16_STABLE [1d3ded521] 2025-08-03 10:50:22 +0900 +Branch: REL_15_STABLE [6914a330f] 2025-08-03 10:50:59 +0900 +--> + <para> + Avoid assertion failure in <application>pgbench</application> when + multiple pipeline sync messages are received (Fujii Masao) + <ulink url="&commit_baseurl;6914a330f">§</ulink> + </para> + </listitem> + + <listitem> +<!-- +Author: Álvaro Herrera <alvherre@kurilemu.de> +Branch: master [0858f0f96] 2025-07-16 19:22:53 +0200 +Branch: REL_18_STABLE [dca0e9693] 2025-07-16 19:22:53 +0200 +Branch: REL_17_STABLE [d07bc7c2b] 2025-07-16 19:22:53 +0200 +Branch: REL_16_STABLE [cef998ef8] 2025-07-16 19:22:53 +0200 +Branch: REL_15_STABLE [5a261c135] 2025-07-16 19:22:53 +0200 +Branch: REL_14_STABLE [e04aca1c4] 2025-07-16 19:22:53 +0200 +Branch: REL_13_STABLE [57949cea5] 2025-07-16 19:22:53 +0200 +--> + <para> + Ensure that <application>pg_dump</application> dumps comments on + domain constraints in a valid order (Jian He) + <ulink url="&commit_baseurl;5a261c135">§</ulink> + </para> + + <para> + In some cases the comment command could appear before creation of + the constraint. + </para> + </listitem> + + <listitem> +<!-- +Author: Noah Misch <noah@leadboat.com> +Branch: master [0decd5e89] 2025-07-31 06:37:56 -0700 +Branch: REL_18_STABLE [c0ae03384] 2025-07-31 06:37:59 -0700 +Branch: REL_17_STABLE [1ca1889ea] 2025-07-31 06:38:00 -0700 +Branch: REL_16_STABLE [0ac1581c3] 2025-07-31 06:38:00 -0700 +Branch: REL_15_STABLE [22f126da6] 2025-07-31 06:38:01 -0700 +Branch: REL_14_STABLE [7ee7c1cd3] 2025-07-31 06:38:02 -0700 +Branch: REL_13_STABLE [04bc2c42f] 2025-07-31 06:38:03 -0700 +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master Release: REL_18_BR [350e6b8ea] 2024-11-04 13:31:12 -0500 +Branch: REL_17_STABLE [5dd4957b2] 2025-07-31 06:38:00 -0700 +Branch: REL_16_STABLE [9affed263] 2025-07-31 06:38:00 -0700 +Branch: REL_15_STABLE [e99010cbd] 2025-07-31 06:38:01 -0700 +Branch: REL_14_STABLE [25388fb2c] 2025-07-31 06:38:02 -0700 +Branch: REL_13_STABLE [cc9a62c51] 2025-07-31 06:38:03 -0700 +Author: Noah Misch <noah@leadboat.com> +Branch: REL_18_STABLE [0d2734eac] 2025-08-10 13:05:13 -0700 +Branch: REL_17_STABLE [28e7252e4] 2025-08-10 13:05:16 -0700 +Branch: REL_16_STABLE [216683296] 2025-08-10 13:05:16 -0700 +Branch: REL_15_STABLE [70637d7ae] 2025-08-10 13:05:17 -0700 +Branch: REL_14_STABLE [7846f4709] 2025-08-10 13:05:17 -0700 +Branch: REL_13_STABLE [bc05590c7] 2025-08-10 13:05:17 -0700 +--> + <para> + Ensure stable sort ordering in <application>pg_dump</application> + for all types of database objects (Noah Misch, Andreas Karlsson) + <ulink url="&commit_baseurl;22f126da6">§</ulink> + <ulink url="&commit_baseurl;e99010cbd">§</ulink> + <ulink url="&commit_baseurl;70637d7ae">§</ulink> + </para> + + <para> + <application>pg_dump</application> sorts objects by their logical + names before performing dependency-driven reordering. This sort did + not account for the full unique key identifying certain object types + such as rules and constraints, and thus it could produce dissimilar + sort orders for logically-identical databases. That made it + difficult to compare databases by + diff'ing <application>pg_dump</application> output, so improve the + logic to ensure stable sort ordering in all cases. + </para> + </listitem> + + <listitem> +<!-- +Author: Álvaro Herrera <alvherre@kurilemu.de> +Branch: master [f295494d3] 2025-07-04 18:05:43 +0200 +Branch: REL_18_STABLE [07da2985d] 2025-07-04 18:05:43 +0200 +Branch: REL_17_STABLE [b8b2e6052] 2025-07-04 18:05:43 +0200 +Branch: REL_16_STABLE [f63e408e8] 2025-07-04 18:05:43 +0200 +Branch: REL_15_STABLE [0f4958685] 2025-07-04 18:05:43 +0200 +Branch: REL_14_STABLE [ea3386cc7] 2025-07-04 18:05:43 +0200 +Branch: REL_13_STABLE [b0f0e2221] 2025-07-04 18:05:43 +0200 +Branch: master [144ad723a] 2025-07-04 21:30:05 +0200 +Branch: REL_18_STABLE [1e007722f] 2025-07-04 21:30:05 +0200 +Branch: REL_17_STABLE [bcb8d47cd] 2025-07-04 21:30:05 +0200 +Branch: REL_16_STABLE [f943e2339] 2025-07-04 21:30:05 +0200 +Branch: REL_15_STABLE [bd48455d8] 2025-07-04 21:30:05 +0200 +Branch: REL_14_STABLE [94dc2b37b] 2025-07-04 21:30:05 +0200 +Branch: REL_13_STABLE [708469281] 2025-07-04 21:30:05 +0200 +Author: Peter Eisentraut <peter@eisentraut.org> +Branch: master [1beda2c3c] 2025-08-07 11:48:43 +0200 +Branch: REL_18_STABLE [1084e76f3] 2025-08-07 11:59:14 +0200 +Branch: REL_17_STABLE [930e1faec] 2025-08-07 11:59:20 +0200 +Branch: REL_16_STABLE [05b367bea] 2025-08-07 11:59:26 +0200 +Branch: REL_15_STABLE [63c79a6fc] 2025-08-07 11:59:32 +0200 +Branch: REL_14_STABLE [a00eb374c] 2025-08-07 11:59:38 +0200 +Branch: REL_13_STABLE [160131033] 2025-08-07 11:59:42 +0200 +Author: Peter Eisentraut <peter@eisentraut.org> +Branch: REL_15_STABLE [22d783350] 2025-08-08 00:18:19 +0200 +Branch: REL_14_STABLE [f9f6595e3] 2025-08-08 00:18:15 +0200 +Branch: REL_13_STABLE [7406a7d82] 2025-08-08 00:18:11 +0200 +Author: Peter Eisentraut <peter@eisentraut.org> +Branch: REL_16_STABLE [06f444816] 2025-08-08 00:27:14 +0200 +Branch: REL_15_STABLE [a8b31b160] 2025-08-08 00:28:58 +0200 +Branch: REL_14_STABLE [ed2bb0cdd] 2025-08-08 00:29:31 +0200 +Branch: REL_13_STABLE [de7fd83cd] 2025-08-08 00:29:34 +0200 +Author: Peter Eisentraut <peter@eisentraut.org> +Branch: REL_15_STABLE [18d2d8ae4] 2025-08-08 08:47:10 +0200 +Branch: REL_14_STABLE [bef2c2a4e] 2025-08-08 08:48:28 +0200 +Branch: REL_13_STABLE [095e83d09] 2025-08-08 08:48:36 +0200 +--> + <para> + In <application>pg_upgrade</application>, check for inconsistent + inherited not-null constraints (Ali Akbar) + <ulink url="&commit_baseurl;0f4958685">§</ulink> + <ulink url="&commit_baseurl;bd48455d8">§</ulink> + <ulink url="&commit_baseurl;63c79a6fc">§</ulink> + <ulink url="&commit_baseurl;22d783350">§</ulink> + <ulink url="&commit_baseurl;a8b31b160">§</ulink> + <ulink url="&commit_baseurl;18d2d8ae4">§</ulink> + </para> + + <para> + <productname>PostgreSQL</productname> versions before 18 allow an + inherited column not-null constraint to be dropped. However, this + results in a schema that cannot be restored, leading to failure + in <application>pg_upgrade</application>. Detect such cases + during <application>pg_upgrade</application>'s preflight checks to + allow users to fix them before initiating the upgrade. + </para> + </listitem> + + <listitem> +<!-- +Author: Michael Paquier <michael@paquier.xyz> +Branch: master [5a6c39b6d] 2025-07-04 15:09:24 +0900 +Branch: REL_18_STABLE [29a4b63c6] 2025-07-04 15:10:17 +0900 +Branch: REL_17_STABLE [ae20c105f] 2025-07-04 15:10:19 +0900 +Branch: REL_16_STABLE [7e7059abf] 2025-07-04 15:10:21 +0900 +Branch: REL_15_STABLE [dcbbd4331] 2025-07-04 15:10:22 +0900 +Branch: REL_14_STABLE [b61ddcaf4] 2025-07-04 15:10:24 +0900 +Branch: REL_13_STABLE [8bca4476f] 2025-07-04 15:10:25 +0900 +--> + <para> + Avoid assertion failure if <varname>track_commit_timestamp</varname> + is enabled during <application>initdb</application> (Hayato Kuroda, + Andy Fan) + <ulink url="&commit_baseurl;dcbbd4331">§</ulink> + </para> + </listitem> + + <listitem> +<!-- +Author: Fujii Masao <fujii@postgresql.org> +Branch: master Release: REL_18_BR [0bd762e81] 2025-05-21 11:55:14 +0900 +Branch: REL_17_STABLE [11efaaffa] 2025-05-21 11:56:24 +0900 +Branch: REL_16_STABLE [0d2063585] 2025-05-21 11:56:32 +0900 +Branch: REL_15_STABLE [0e0174b49] 2025-05-21 11:56:39 +0900 +--> + <para> + Fix <application>pg_waldump</application> to show information about + dropped statistics in <literal>PREPARE TRANSACTION</literal> WAL + records (Daniil Davydov) + <ulink url="&commit_baseurl;0e0174b49">§</ulink> + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master Release: REL_18_BR [470273da0] 2025-05-29 10:39:55 -0400 +Branch: REL_17_STABLE [e20b3256a] 2025-05-29 10:39:55 -0400 +Branch: REL_16_STABLE [8eef55db1] 2025-05-29 10:39:55 -0400 +Branch: REL_15_STABLE [09c9ae8f6] 2025-05-29 10:39:55 -0400 +Branch: REL_14_STABLE [2cd2222ca] 2025-05-29 10:39:55 -0400 +Branch: REL_13_STABLE [e7d3d4ed4] 2025-05-29 10:39:55 -0400 +--> + <para> + Avoid possible leak of the open connection + during <filename>contrib/dblink</filename> connection establishment + (Tom Lane) + <ulink url="&commit_baseurl;09c9ae8f6">§</ulink> + </para> + + <para> + In the rare scenario where we hit out-of-memory while inserting the + new connection object into dblink's hashtable, the open connection + would be leaked until end of session, leaving an idle session + sitting on the remote server. + </para> + </listitem> + + <listitem> +<!-- +Author: Robert Haas <rhaas@postgresql.org> +Branch: master Release: REL_18_BR [016e407f4] 2025-06-06 08:18:27 -0400 +Branch: REL_17_STABLE [e4b8f925a] 2025-06-06 08:18:26 -0400 +Branch: REL_16_STABLE [169429264] 2025-06-06 08:18:23 -0400 +Branch: REL_15_STABLE [d59ff3be2] 2025-06-06 08:18:22 -0400 +Branch: REL_14_STABLE [a4b9707c4] 2025-06-06 08:18:20 -0400 +Branch: REL_13_STABLE [4adbaa36c] 2025-06-06 08:18:15 -0400 +--> + <para> + Make <filename>contrib/pg_prewarm</filename> cope with very + large <varname>shared_buffers</varname> settings (Daria Shanina) + <ulink url="&commit_baseurl;d59ff3be2">§</ulink> + </para> + + <para> + Autoprewarm failed with a memory allocation error + if <varname>shared_buffers</varname> was larger than about 50 + million buffers (400GB). + </para> + </listitem> + + <listitem> +<!-- +Author: Michael Paquier <michael@paquier.xyz> +Branch: master Release: REL_18_BR [35a428f30] 2025-05-29 11:26:03 +0900 +Branch: REL_17_STABLE [290e8ab32] 2025-05-29 11:26:23 +0900 +Branch: REL_16_STABLE [7e8b44f4e] 2025-05-29 11:26:27 +0900 +Branch: REL_15_STABLE [130300a15] 2025-05-29 11:26:29 +0900 +Branch: REL_14_STABLE [8a1459f62] 2025-05-29 11:26:31 +0900 +Branch: REL_13_STABLE [3c03b8cd7] 2025-05-29 11:26:34 +0900 +--> + <para> + In <filename>contrib/pg_stat_statements</filename>, avoid leaving + gaps in the set of parameter numbers used in a normalized query + (Sami Imseih) + <ulink url="&commit_baseurl;130300a15">§</ulink> + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master Release: REL_18_BR [232d8caea] 2025-05-30 13:45:41 -0400 +Branch: REL_17_STABLE [9339c85af] 2025-05-30 13:45:41 -0400 +Branch: REL_16_STABLE [2b92dc4ee] 2025-05-30 13:45:41 -0400 +Branch: REL_15_STABLE [3c31594f5] 2025-05-30 13:45:41 -0400 +Branch: REL_14_STABLE [4a07c0961] 2025-05-30 13:45:41 -0400 +Branch: REL_13_STABLE [271cb7eaa] 2025-05-30 13:45:41 -0400 +--> + <para> + Fix memory leakage in <filename>contrib/postgres_fdw</filename>'s + DirectModify methods (Tom Lane) + <ulink url="&commit_baseurl;3c31594f5">§</ulink> + </para> + + <para> + The <structname>PGresult</structname> holding the results of the + remote modify command would be leaked for the rest of the session if + the query fails between invocations of the DirectModify methods, + which could happen when there's <literal>RETURNING</literal> data to + process. + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master [4300d8b6a] 2025-07-29 15:17:40 -0400 +Branch: REL_18_STABLE [8e5e3ff55] 2025-07-29 15:17:40 -0400 +Branch: REL_17_STABLE [a644f5fc6] 2025-07-29 15:17:41 -0400 +Branch: REL_16_STABLE [bbc20c8a9] 2025-07-29 15:17:41 -0400 +Branch: REL_15_STABLE [19857437b] 2025-07-29 15:17:41 -0400 +Branch: REL_14_STABLE [2dee95bd0] 2025-07-29 15:17:41 -0400 +Branch: REL_13_STABLE [c5bd803e5] 2025-07-29 15:17:41 -0400 +--> + <para> + Ensure that directories listed + in <application>configure</application>'s + <option>--with-includes</option> + and <option>--with-libraries</option> options are searched before + system-supplied directories (Tom Lane) + <ulink url="&commit_baseurl;19857437b">§</ulink> + </para> + + <para> + A common reason for using these options is to allow a user-built + version of some library to override the system-supplied version. + However, that failed to work in some environments because of + careless ordering of switches in the commands issued by the makefiles. + </para> + </listitem> + + <listitem> +<!-- +Author: Michael Paquier <michael@paquier.xyz> +Branch: master [1a5212775] 2025-07-30 11:55:42 +0900 +Branch: REL_18_STABLE [cd2d52cc6] 2025-07-30 11:55:46 +0900 +Branch: REL_17_STABLE [8de56323c] 2025-07-30 11:55:47 +0900 +Branch: REL_16_STABLE [c1984be23] 2025-07-30 11:55:49 +0900 +Branch: REL_15_STABLE [d6ffc43f9] 2025-07-30 11:55:51 +0900 +Branch: REL_14_STABLE [60953d4cb] 2025-07-30 11:55:53 +0900 +Branch: REL_13_STABLE [612f5b806] 2025-07-30 11:55:54 +0900 +--> + <para> + Fix <application>configure</application>'s checks + for <function>__cpuid()</function> + and <function>__cpuidex()</function> (Lukas Fittl, Michael Paquier) + <ulink url="&commit_baseurl;d6ffc43f9">§</ulink> + </para> + + <para> + <application>configure</application> failed to detect these + Windows-specific functions, so that they would not be used, + leading to slower-than-necessary CRC computations since the + availability of hardware instructions could not be verified. + The practical impact of this error was limited, because production + builds for Windows typically do not use the Autoconf toolchain. + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master [e6dfd068e] 2025-07-23 15:44:29 -0400 +Branch: REL_18_STABLE [3d039b53a] 2025-07-23 15:44:29 -0400 +Branch: REL_17_STABLE [635a85627] 2025-07-23 15:44:29 -0400 +Branch: REL_16_STABLE [e4d585455] 2025-07-23 15:44:29 -0400 +Branch: REL_15_STABLE [b252ce311] 2025-07-23 15:44:29 -0400 +Branch: REL_14_STABLE [868b39a54] 2025-07-23 15:44:29 -0400 +Branch: REL_13_STABLE [1ccb3851d] 2025-07-23 15:44:29 -0400 +--> + <para> + Fix build failure with <option>--with-pam</option> option on + Solaris-based platforms (Tom Lane) + <ulink url="&commit_baseurl;b252ce311">§</ulink> + </para> + + <para> + Solaris is inconsistent with other Unix platforms about the API for + PAM authentication. This manifested as an <quote>inconsistent + pointer</quote> compiler warning, which we never did anything about. + But as of GCC 14 it's an error not warning by default, so fix it. + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master [1fd772d19] 2025-07-01 12:40:35 -0400 +Branch: REL_18_STABLE [581305a46] 2025-07-01 12:40:35 -0400 +Branch: REL_17_STABLE [0991249d7] 2025-07-01 12:40:35 -0400 +Branch: REL_16_STABLE [d25d392e8] 2025-07-01 12:40:35 -0400 +Branch: master [29213636e] 2025-07-01 12:08:20 -0400 +Branch: REL_18_STABLE [45c527662] 2025-07-01 12:08:20 -0400 +Branch: REL_17_STABLE [29c54ea7b] 2025-07-01 12:08:20 -0400 +Branch: REL_16_STABLE [3a2617e4f] 2025-07-01 12:08:20 -0400 +Branch: REL_15_STABLE [0fb496c70] 2025-07-01 12:08:57 -0400 +Branch: REL_14_STABLE [71d71ac4d] 2025-07-01 12:08:57 -0400 +Branch: REL_13_STABLE [d0a695cf4] 2025-07-01 12:08:58 -0400 +--> + <para> + Make our code portable to GNU Hurd (Michael Banck, Christoph Berg, + Samuel Thibault) + <ulink url="&commit_baseurl;0fb496c70">§</ulink> + </para> + + <para> + Fix assumptions about <literal>IOV_MAX</literal> + and <literal>O_RDONLY</literal> that don't hold on Hurd. + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master Release: REL_18_BR [12eee85e5] 2025-05-18 12:45:55 -0400 +Branch: REL_17_STABLE [5355a2400] 2025-05-18 12:45:55 -0400 +Branch: REL_16_STABLE [253cf661c] 2025-05-18 12:45:55 -0400 +Branch: REL_16_STABLE [4b53cb493] 2025-05-20 10:55:05 -0400 +Branch: REL_15_STABLE [00652b3c9] 2025-05-18 12:45:55 -0400 +Branch: REL_14_STABLE [a1e0e7076] 2025-05-18 12:45:55 -0400 +Branch: REL_13_STABLE [9bc2d37cc] 2025-05-18 12:45:55 -0400 +--> + <para> + Make our usage of <function>memset_s()</function> conform strictly + to the C11 standard (Tom Lane) + <ulink url="&commit_baseurl;00652b3c9">§</ulink> + </para> + + <para> + This avoids compile failures on some platforms. + </para> + </listitem> + + <listitem> +<!-- +Author: Tom Lane <tgl@sss.pgh.pa.us> +Branch: master [aad1617b7] 2025-07-15 18:11:18 -0400 +Branch: REL_18_STABLE [0b6dfce0c] 2025-07-15 18:11:18 -0400 +Branch: REL_17_STABLE [5a2139a90] 2025-07-15 18:11:18 -0400 +Branch: REL_16_STABLE [5db55e13f] 2025-07-15 18:11:18 -0400 +Branch: REL_15_STABLE [f32e45641] 2025-07-15 18:11:18 -0400 +Branch: REL_14_STABLE [8254b7e33] 2025-07-15 18:11:18 -0400 +Branch: REL_13_STABLE [6c93bf735] 2025-07-15 18:11:18 -0400 +--> + <para> + Prevent uninitialized-value compiler warnings in JSONB comparison + code (Tom Lane) + <ulink url="&commit_baseurl;f32e45641">§</ulink> + </para> + </listitem> + + <listitem> +<!-- +Author: Michael Paquier <michael@paquier.xyz> +Branch: master [8aa54aa7e] 2025-07-07 08:53:57 +0900 +Branch: REL_18_STABLE [8d1071e7d] 2025-07-07 08:54:30 +0900 +Branch: REL_17_STABLE [c911e7802] 2025-07-07 08:54:37 +0900 +Branch: REL_16_STABLE [d24a96ce2] 2025-07-07 08:54:39 +0900 +Branch: REL_15_STABLE [75c1eb60b] 2025-07-07 08:54:41 +0900 +Branch: REL_14_STABLE [ac166b19a] 2025-07-07 08:54:43 +0900 +Branch: REL_13_STABLE [e688cfc2b] 2025-07-07 08:54:44 +0900 +--> + <para> + Avoid deprecation warnings when building + with <application>libxml2</application> 2.14 and later + (Michael Paquier) + <ulink url="&commit_baseurl;75c1eb60b">§</ulink> + </para> + </listitem> + + <listitem> +<!-- +Author: John Naylor <john.naylor@postgresql.org> +Branch: master [ed26c4e25] 2025-07-09 14:20:22 +0700 +Branch: master [90bfae9f9] 2025-08-07 17:10:52 +0700 +Branch: REL_18_STABLE [dd2926207] 2025-08-07 17:12:44 +0700 +Branch: REL_17_STABLE [21ae8fc5f] 2025-08-07 17:13:55 +0700 +Branch: REL_16_STABLE [aae9aad19] 2025-08-07 17:14:39 +0700 +Branch: REL_15_STABLE [baacfb9e6] 2025-08-07 17:15:09 +0700 +Branch: REL_14_STABLE [a4f891b96] 2025-08-07 17:16:00 +0700 +Branch: REL_13_STABLE [9560c1ec1] 2025-08-07 17:16:33 +0700 +--> + <para> + Avoid problems when compiling <filename>pg_locale.h</filename> under + C++ (John Naylor) + <ulink url="&commit_baseurl;baacfb9e6">§</ulink> + </para> + + <para> + <productname>PostgreSQL</productname> header files generally need to + be wrapped in <literal>extern "C" { ... }</literal> in order to be + included in extensions written in C++. This failed + for <filename>pg_locale.h</filename> because of its use + of <application>libicu</application> headers, but we can work around + that by suppressing C++-only declarations in those headers. C++ + extensions that want to use <application>libicu</application>'s C++ + APIs can do so by including the <application>libicu</application> + headers ahead of <filename>pg_locale.h</filename>. + </para> + </listitem> + + </itemizedlist> + + </sect2> + </sect1> + <sect1 id="release-15-13"> <title>Release 15.13</title> |