summaryrefslogtreecommitdiffstats
path: root/doc/src/sgml/html/release-15.html
blob: 5f14523addcefaff35c3f9e10cf4cfc08f64ee2f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /><title>E.5. Release 15</title><link rel="stylesheet" type="text/css" href="stylesheet.css" /><link rev="made" href="pgsql-docs@lists.postgresql.org" /><meta name="generator" content="DocBook XSL Stylesheets Vsnapshot" /><link rel="prev" href="release-15-1.html" title="E.4. Release 15.1" /><link rel="next" href="release-prior.html" title="E.6. Prior Releases" /></head><body id="docContent" class="container-fluid col-10"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="5" align="center">E.5. Release 15</th></tr><tr><td width="10%" align="left"><a accesskey="p" href="release-15-1.html" title="E.4. Release 15.1">Prev</a> </td><td width="10%" align="left"><a accesskey="u" href="release.html" title="Appendix E. Release Notes">Up</a></td><th width="60%" align="center">Appendix E. Release Notes</th><td width="10%" align="right"><a accesskey="h" href="index.html" title="PostgreSQL 15.4 Documentation">Home</a></td><td width="10%" align="right"> <a accesskey="n" href="release-prior.html" title="E.6. Prior Releases">Next</a></td></tr></table><hr /></div><div class="sect1" id="RELEASE-15"><div class="titlepage"><div><div><h2 class="title" style="clear: both">E.5. Release 15</h2></div></div></div><div class="toc"><dl class="toc"><dt><span class="sect2"><a href="release-15.html#id-1.11.6.9.3">E.5.1. Overview</a></span></dt><dt><span class="sect2"><a href="release-15.html#id-1.11.6.9.4">E.5.2. Migration to Version 15</a></span></dt><dt><span class="sect2"><a href="release-15.html#id-1.11.6.9.5">E.5.3. Changes</a></span></dt><dt><span class="sect2"><a href="release-15.html#RELEASE-15-ACKNOWLEDGEMENTS">E.5.4. Acknowledgments</a></span></dt></dl></div><p><strong>Release date: </strong>2022-10-13</p><div class="sect2" id="id-1.11.6.9.3"><div class="titlepage"><div><div><h3 class="title">E.5.1. Overview</h3></div></div></div><p>
    <span class="productname">PostgreSQL</span> 15 contains many new features
    and enhancements, including:
   </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
      Support for the <acronym class="acronym">SQL</acronym>
      <a class="link" href="sql-merge.html" title="MERGE"><code class="command">MERGE</code></a> command.
     </p></li><li class="listitem"><p>
      Selective publication of tables' contents within
      <a class="link" href="logical-replication.html" title="Chapter 31. Logical Replication">logical replication</a>
      publications, through the ability to specify column lists and
      row filter conditions.
     </p></li><li class="listitem"><p>
      More options for compression, including support for Zstandard (zstd)
      compression.  This includes support for performing compression on
      the server side during
      <a class="link" href="app-pgbasebackup.html" title="pg_basebackup"><span class="application">pg_basebackup</span></a>.
     </p></li><li class="listitem"><p>
      Support for structured <a class="link" href="runtime-config-logging.html#GUC-LOG-DESTINATION">server
      log output</a> using the <acronym class="acronym">JSON</acronym> format.
     </p></li><li class="listitem"><p>
      Performance improvements, particularly for in-memory and on-disk
      sorting.
     </p></li></ul></div><p>
    The above items and other new features of
    <span class="productname">PostgreSQL</span> 15 are explained in more detail
    in the sections below.
   </p></div><div class="sect2" id="id-1.11.6.9.4"><div class="titlepage"><div><div><h3 class="title">E.5.2. Migration to Version 15</h3></div></div></div><p>
     A dump/restore using <a class="xref" href="app-pg-dumpall.html" title="pg_dumpall"><span class="refentrytitle"><span class="application">pg_dumpall</span></span></a> or use of
     <a class="xref" href="pgupgrade.html" title="pg_upgrade"><span class="refentrytitle"><span class="application">pg_upgrade</span></span></a> or logical replication is required for
     those wishing to migrate data from any previous release.  See <a class="xref" href="upgrading.html" title="19.6. Upgrading a PostgreSQL Cluster">Section 19.6</a> for general information on migrating to new
     major releases.
    </p><p>
     Version 15 contains a number of changes that may affect compatibility
     with previous releases.  Observe the following incompatibilities:
    </p><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
      Remove <code class="literal">PUBLIC</code> creation permission on the <a class="link" href="ddl-schemas.html#DDL-SCHEMAS-PUBLIC" title="5.9.2. The Public Schema"><code class="literal">public</code> schema</a>
      (Noah Misch)
     </p><p>
      The new default is one of the secure schema usage patterns that <a class="xref" href="ddl-schemas.html#DDL-SCHEMAS-PATTERNS" title="5.9.6. Usage Patterns">Section 5.9.6</a> has recommended since the security
      release for CVE-2018-1058.  The change applies to new database
      clusters and to newly-created databases in existing clusters.
      Upgrading a cluster or restoring a database dump will preserve
      <code class="literal">public</code>'s existing permissions.
     </p><p>
      For existing databases, especially those having multiple users,
      consider revoking <code class="literal">CREATE</code> permission on
      the <code class="literal">public</code> schema to adopt this new default.
      For new databases having no need to defend against insider threats,
      granting <code class="literal">CREATE</code> permission will yield the behavior
      of prior releases.
     </p></li><li class="listitem"><p>
      Change the owner of the <code class="literal">public</code> schema to be the
      new <code class="literal">pg_database_owner</code> role (Noah Misch)
     </p><p>
      This allows each database's owner to have ownership privileges on
      the <code class="literal">public</code> schema within their database.
      Previously it was owned by the bootstrap superuser, so that
      non-superuser database owners could not do anything with it.
     </p><p>
      This change applies to new database clusters and to newly-created
      databases in existing clusters.
      Upgrading a cluster or restoring a database dump will preserve
      <code class="literal">public</code>'s existing ownership specification.
     </p></li><li class="listitem"><p>
      Remove long-deprecated <a class="link" href="continuous-archiving.html#BACKUP-BASE-BACKUP" title="26.3.2. Making a Base Backup">exclusive
      backup mode</a> (David Steele, Nathan Bossart)
     </p><p>
      If the database server stops abruptly while in this mode, the
      server could fail to start.  The non-exclusive backup mode is
      considered superior for all purposes.  Functions
      <code class="function">pg_start_backup()</code>/<code class="function">pg_stop_backup()</code>
      have been renamed to
      <code class="function">pg_backup_start()</code>/<code class="function">pg_backup_stop()</code>,
      and the functions <code class="function">pg_backup_start_time()</code>
      and <code class="function">pg_is_in_backup()</code> have been removed.
     </p></li><li class="listitem"><p>
      Increase <a class="link" href="runtime-config-resource.html#GUC-HASH-MEM-MULTIPLIER"><code class="varname">hash_mem_multiplier</code></a>
      default to 2.0 (Peter Geoghegan)
     </p><p>
      This allows query hash operations to use more
      <a class="link" href="runtime-config-resource.html#GUC-WORK-MEM"><code class="varname">work_mem</code></a>
      memory than other operations.
     </p></li><li class="listitem"><p>
      Remove server-side language <a class="link" href="plpython.html" title="Chapter 46. PL/Python — Python Procedural Language"><code class="literal">plpython2u</code></a> and generic
      Python language <code class="literal">plpythonu</code> (Andres Freund)
     </p><p>
      Python 2.x is no longer supported.  While the original intent of
      <code class="literal">plpythonu</code> was that it could eventually refer
      to <code class="literal">plpython3u</code>, changing it now seems more likely
      to cause problems than solve them, so it's just been removed.
     </p></li><li class="listitem"><p>
      Generate an error if <a class="link" href="functions-textsearch.html#TEXTSEARCH-FUNCTIONS-TABLE" title="Table 9.43. Text Search Functions"><code class="function">array_to_tsvector()</code></a>
      is passed an empty-string array element (Jean-Christophe Arnu)
     </p><p>
      This is prohibited because lexemes should never be empty.  Users of
      previous Postgres releases should verify that no empty lexemes
      are stored because they can lead to dump/restore failures and
      inconsistent results.
     </p></li><li class="listitem"><p>
      Generate an error when <a class="link" href="functions-string.html#FUNCTIONS-STRING-OTHER" title="Table 9.10. Other String Functions and Operators"><code class="function">chr()</code></a>
      is supplied with a negative argument (Peter Eisentraut)
     </p></li><li class="listitem"><p>
      Prevent <a class="link" href="sql-createview.html" title="CREATE VIEW"><code class="command">CREATE OR REPLACE
      VIEW</code></a> from changing the collation of an output column
      (Tom Lane)
     </p></li><li class="listitem"><p>
      Disallow zero-length <a class="link" href="sql-syntax-lexical.html#SQL-SYNTAX-IDENTIFIERS" title="4.1.1. Identifiers and Key Words">Unicode identifiers</a>,
      e.g., <code class="literal">U&amp;""</code>
      (Peter Eisentraut)
     </p><p>
      Non-Unicode zero-length identifiers were already disallowed.
     </p></li><li class="listitem"><p>
      Prevent <a class="link" href="sql-syntax-lexical.html#SQL-SYNTAX-CONSTANTS-NUMERIC" title="4.1.2.6. Numeric Constants">numeric
      literals</a> from having non-numeric trailing characters (Peter
      Eisentraut)
     </p><p>
      Previously, query text like <code class="literal">123abc</code> would be
      interpreted as <code class="literal">123</code> followed
      by a separate token <code class="literal">abc</code>.
     </p></li><li class="listitem"><p>
      Adjust <a class="link" href="datatype-json.html" title="8.14. JSON Types"><acronym class="acronym">JSON</acronym></a>
      numeric literal processing to match the
      <acronym class="acronym">SQL</acronym>/<acronym class="acronym">JSON</acronym>-standard (Peter
      Eisentraut)
     </p><p>
      This accepts numeric formats like <code class="literal">.1</code> and
      <code class="literal">1.</code>, and disallows trailing junk after numeric
      literals, like <code class="literal">1.type()</code>.
     </p></li><li class="listitem"><p>
      When <a class="link" href="datatype-datetime.html" title="8.5. Date/Time Types"><code class="type">interval</code></a>
      input provides a fractional value for a unit greater than months,
      round to the nearest month (Bruce Momjian)
     </p><p>
      For example, convert <code class="literal">1.99 years</code> to <code class="literal">2
      years</code>, not <code class="literal">1 year 11 months</code> as before.
     </p></li><li class="listitem"><p>
      Improve consistency of <code class="type">interval</code> parsing with trailing
      periods (Tom Lane)
     </p><p>
      Numbers with trailing periods were rejected on some platforms.
     </p></li><li class="listitem"><p>
      Mark the <code class="type">interval</code> output
      function as stable, not immutable, since it depends on <a class="link" href="runtime-config-client.html#GUC-INTERVALSTYLE"><code class="varname">IntervalStyle</code></a>
      (Tom Lane)
     </p><p>
      This will, for example, cause creation of indexes relying on the
      text output of <code class="type">interval</code> values to fail.
     </p></li><li class="listitem"><p>
      Detect integer overflow in <a class="link" href="functions-datetime.html#FUNCTIONS-DATETIME-TABLE" title="Table 9.33. Date/Time Functions">interval justification
      functions</a> (Joe Koshakow)
     </p><p>
      The affected functions are <code class="function">justify_interval()</code>,
      <code class="function">justify_hours()</code>, and
      <code class="function">justify_days()</code>.
     </p></li><li class="listitem"><p>
      Change the I/O format of type <code class="type">"char"</code> for non-ASCII
      characters (Tom Lane)
     </p><p>
      Bytes with the high bit set are now output as a backslash and three
      octal digits, to avoid encoding issues.
     </p></li><li class="listitem"><p>
      Remove the default <a class="link" href="sql-createrole.html" title="CREATE ROLE"><code class="literal">ADMIN
      OPTION</code></a> privilege a login role has on its own role
      membership (Robert Haas)
     </p><p>
      Previously, a login role could add/remove members of its own role,
      even without <code class="literal">ADMIN OPTION</code> privilege.
     </p></li><li class="listitem"><p>
      Allow <a class="link" href="logical-replication.html" title="Chapter 31. Logical Replication">logical replication</a>
      to run as the owner of the subscription (Mark Dilger)
     </p><p>
      Because row-level security policies are not checked, only superusers,
      roles with <code class="literal">bypassrls</code>, and table owners can
      replicate into tables with row-level security policies.
     </p></li><li class="listitem"><p>
      Prevent <code class="command">UPDATE</code> and <code class="command">DELETE</code>
      <a class="link" href="logical-replication.html" title="Chapter 31. Logical Replication">logical replication</a>
      operations on tables where the subscription owner does not have
      <code class="command">SELECT</code> permission on the table (Jeff Davis)
     </p><p>
      <code class="command">UPDATE</code> and <code class="command">DELETE</code> commands
      typically involve reading the table as well, so require the
      subscription owner to have table <code class="command">SELECT</code>
      permission.
     </p></li><li class="listitem"><p>
      When <a class="link" href="sql-explain.html" title="EXPLAIN"><code class="command">EXPLAIN</code></a>
      references the session's temporary object schema, refer to it as
      <code class="literal">pg_temp</code> (Amul Sul)
     </p><p>
      Previously the actual schema name was reported, leading to
      inconsistencies across sessions.
     </p></li><li class="listitem"><p>
      Fix <a class="link" href="monitoring-stats.html#MONITORING-PG-STATIO-ALL-TABLES-VIEW" title="28.2.19. pg_statio_all_tables"><code class="structname">pg_statio_all_tables</code></a>
      to sum values for the rare case of <acronym class="acronym">TOAST</acronym> tables
      with multiple indexes (Andrei Zubkov)
     </p><p>
      Previously such cases would show one row for each index.
     </p></li><li class="listitem"><p>
      Disallow setting <a class="link" href="runtime-config-custom.html" title="20.16. Customized Options">custom
      options</a> that match the name of an installed extension, but
      are not one of the extension's declared variables
      (Florin Irion, Tom Lane)
     </p><p>
      This change causes any such pre-existing variables to be deleted
      during extension load, and then prevents new ones from being created
      later in the session.  The intent is to prevent confusion about
      whether a variable is associated with an extension or not.
     </p></li><li class="listitem"><p>
      Remove obsolete server variable
      <code class="varname">stats_temp_directory</code> (Andres Freund, Kyotaro
      Horiguchi)
     </p></li><li class="listitem"><p>
      Improve the algorithm used to compute <a class="link" href="functions-math.html#FUNCTIONS-MATH-RANDOM-TABLE" title="Table 9.6. Random Functions"><code class="function">random()</code></a>
      (Fabien Coelho)
     </p><p>
      This will cause <code class="function">random()</code>'s results to differ
      from what was emitted by prior versions, even for the same seed
      value.
     </p></li><li class="listitem"><p>
      <span class="application">libpq</span>'s <a class="link" href="libpq-async.html#LIBPQ-PQSENDQUERY"><code class="function">PQsendQuery()</code></a>
      function is no longer supported in pipeline mode (Álvaro Herrera)
     </p><p>
      Applications that are using that combination will need to be
      modified to use <code class="function">PQsendQueryParams()</code> instead.
     </p></li><li class="listitem"><p>
      On non-Windows platforms, consult the <code class="envar">HOME</code> environment
      variable to find the user's home directory (Anders Kaseorg)
     </p><p>
      If <code class="envar">HOME</code> is empty or unset, fall back to the previous
      method of checking the <code class="literal">&lt;pwd.h&gt;</code> database.
      This change affects <span class="application">libpq</span> (for example,
      while looking up <code class="filename">~/.pgpass</code>) as well as various
      client application programs.
     </p></li><li class="listitem"><p>
      Remove <a class="link" href="app-pgdump.html" title="pg_dump"><span class="application">pg_dump</span></a>'s
      <code class="option">--no-synchronized-snapshots</code> option (Tom Lane)
     </p><p>
      All still-supported server versions support synchronized snapshots,
      so there's no longer a need for this option.
     </p></li><li class="listitem"><p>
        After an error is detected in <a class="link" href="app-psql.html" title="psql"><span class="application">psql</span></a>'s
        <code class="option">--single-transaction</code> mode, change the
        final <code class="command">COMMIT</code> command
        to <code class="command">ROLLBACK</code> only
        if <code class="varname">ON_ERROR_STOP</code> is set (Michael Paquier)
       </p></li><li class="listitem"><p>
      Avoid unnecessary casting of constants in queries sent by <a class="link" href="postgres-fdw.html" title="F.38. postgres_fdw">postgres_fdw</a> (Dian Fay)
     </p><p>
      When column types are intentionally different between local and
      remote databases, such casts could cause errors.
     </p></li><li class="listitem"><p>
      Remove <a class="link" href="xml2.html" title="F.50. xml2">xml2</a>'s
      <code class="function">xml_is_well_formed()</code> function (Tom Lane)
     </p><p>
      This function has been implemented in the core backend since
      Postgres 9.1.
     </p></li><li class="listitem"><p>
      Allow <a class="link" href="custom-scan.html" title="Chapter 61. Writing a Custom Scan Provider">custom scan providers</a>
      to indicate if they support projections (Sven Klemm)
     </p><p>
      The default is now that custom scan providers are assumed to not
      support projections;  those that do will need to be updated for
      this release.
     </p></li></ul></div></div><div class="sect2" id="id-1.11.6.9.5"><div class="titlepage"><div><div><h3 class="title">E.5.3. Changes</h3></div></div></div><p>
    Below you will find a detailed account of the changes between
    <span class="productname">PostgreSQL</span> 15 and the previous major
    release.
   </p><div class="sect3" id="id-1.11.6.9.5.3"><div class="titlepage"><div><div><h4 class="title">E.5.3.1. Server</h4></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
       Record and check the collation version of each <a class="link" href="sql-createdatabase.html" title="CREATE DATABASE">database</a> (Peter Eisentraut)
      </p><p>
       This feature is designed to detect collation version
       changes to avoid index corruption.  Function
       <code class="function">pg_database_collation_actual_version()</code>
       reports the underlying operating system collation version, and
       <code class="command">ALTER DATABASE ...  REFRESH</code> sets the recorded
       database collation version to match the operating system collation
       version.
      </p></li><li class="listitem"><p>
       Allow <a class="link" href="locale.html" title="24.1. Locale Support"><acronym class="acronym">ICU</acronym></a>
       collations to be set as the default for clusters and databases
       (Peter Eisentraut)
      </p><p>
       Previously, only <span class="application">libc</span>-based
       collations could be selected at the cluster and database levels.
       <acronym class="acronym">ICU</acronym> collations could only be used via explicit
       <code class="literal">COLLATE</code> clauses.
      </p></li><li class="listitem"><p>
       Add system view <a class="link" href="view-pg-ident-file-mappings.html" title="54.10. pg_ident_file_mappings"><code class="structname">pg_ident_file_mappings</code></a>
       to report <code class="filename">pg_ident.conf</code> information (Julien
       Rouhaud)
      </p></li></ul></div><div class="sect4" id="id-1.11.6.9.5.3.3"><div class="titlepage"><div><div><h5 class="title">E.5.3.1.1. <a class="link" href="ddl-partitioning.html" title="5.11. Table Partitioning">Partitioning</a></h5></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
        Improve planning time for queries referencing partitioned tables
        (David Rowley)
       </p><p>
        This change helps when only a few of many partitions are relevant.
       </p></li><li class="listitem"><p>
        Allow ordered scans of partitions to avoid sorting in more cases
        (David Rowley)
       </p><p>
        Previously, a partitioned table with a <code class="literal">DEFAULT</code>
        partition or a <code class="literal">LIST</code> partition containing
        multiple values could not be used for ordered partition scans.
        Now they can be used if such partitions are pruned during planning.
       </p></li><li class="listitem"><p>
        Improve foreign key behavior of updates on partitioned tables
        that move rows between partitions (Amit Langote)
       </p><p>
        Previously, such updates ran a delete action on the source
        partition and an insert action on the target partition.
        <span class="productname">PostgreSQL</span> will now run an update action
        on the partition root, providing cleaner semantics.
       </p></li><li class="listitem"><p>
        Allow <a class="link" href="sql-cluster.html" title="CLUSTER"><code class="command">CLUSTER</code></a>
        on partitioned tables (Justin Pryzby)
       </p></li><li class="listitem"><p>
        Fix <a class="link" href="sql-altertable.html" title="ALTER TABLE"><code class="command">ALTER TRIGGER
        RENAME</code></a> on partitioned tables to properly rename
        triggers on all partitions (Arne Roland, Álvaro Herrera)
       </p><p>
        Also prohibit cloned triggers from being renamed.
       </p></li></ul></div></div><div class="sect4" id="id-1.11.6.9.5.3.4"><div class="titlepage"><div><div><h5 class="title">E.5.3.1.2. Indexes</h5></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
        Allow btree indexes on system and <a class="link" href="storage-toast.html" title="73.2. TOAST"><acronym class="acronym">TOAST</acronym></a>
        tables to efficiently store duplicates (Peter Geoghegan)
       </p><p>
        Previously de-duplication was disabled for these types of indexes.
       </p></li><li class="listitem"><p>
        Improve lookup performance
        of <a class="link" href="gist.html" title="Chapter 68. GiST Indexes"><acronym class="acronym">GiST</acronym></a> indexes
        that were built using sorting (Aliaksandr Kalenik, Sergei
        Shoulbakov, Andrey Borodin)
       </p></li><li class="listitem"><p>
        Allow unique constraints and indexes to treat
        <code class="literal">NULL</code> values as not distinct (Peter Eisentraut)
       </p><p>
        Previously <code class="literal">NULL</code> entries were always treated
        as distinct values, but this can now be changed by creating
        constraints and indexes using <code class="literal">UNIQUE NULLS NOT
        DISTINCT</code>.
       </p></li><li class="listitem"><p>
        Allow the <a class="link" href="functions-string.html#FUNCTIONS-STRING-OTHER" title="Table 9.10. Other String Functions and Operators"><code class="literal">^@</code></a>
        starts-with operator and the <code class="function">starts_with()</code>
        function to use btree indexes if using the C collation (Tom Lane)
       </p><p>
        Previously these could only use <a class="link" href="spgist.html" title="Chapter 69. SP-GiST Indexes"><acronym class="acronym">SP-GiST</acronym></a> indexes.
       </p></li></ul></div></div><div class="sect4" id="id-1.11.6.9.5.3.5"><div class="titlepage"><div><div><h5 class="title">E.5.3.1.3. Optimizer</h5></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
        Allow <a class="link" href="sql-createstatistics.html" title="CREATE STATISTICS">extended
        statistics</a> to record statistics for a parent with all its
        children (Tomas Vondra, Justin Pryzby)
       </p><p>
        Regular statistics already tracked parent and
        parent-plus-all-children statistics separately.
       </p></li><li class="listitem"><p>
        Add server variable <a class="link" href="runtime-config-query.html#GUC-RECURSIVE-WORKTABLE-FACTOR"><code class="varname">recursive_worktable_factor</code></a>
        to allow the user to specify the expected size of the working
        table of a <a class="link" href="queries-with.html#QUERIES-WITH-RECURSIVE" title="7.8.2. Recursive Queries">recursive
        query</a> (Simon Riggs)
       </p></li></ul></div></div><div class="sect4" id="id-1.11.6.9.5.3.6"><div class="titlepage"><div><div><h5 class="title">E.5.3.1.4. General Performance</h5></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
        Allow hash lookup for <a class="link" href="functions-subquery.html#FUNCTIONS-SUBQUERY-NOTIN" title="9.23.3. NOT IN"><code class="literal">NOT IN</code></a>
        clauses with many constants (David Rowley, James Coleman)
       </p><p>
        Previously the code always sequentially scanned the list of values.
       </p></li><li class="listitem"><p>
       Allow <code class="command">SELECT DISTINCT</code> to be parallelized
       (David Rowley)
      </p></li><li class="listitem"><p>
        Speed up encoding validation of <acronym class="acronym">UTF</acronym>-8 text
        by processing 16 bytes at a time
        (John Naylor, Heikki Linnakangas)
       </p><p>
        This will improve text-heavy operations like <a class="link" href="sql-copy.html" title="COPY"><code class="command">COPY FROM</code></a>.
       </p></li><li class="listitem"><p>
        Improve performance for sorts that exceed <a class="link" href="runtime-config-resource.html#GUC-WORK-MEM"><code class="varname">work_mem</code></a>
        (Heikki Linnakangas)
       </p><p>
        When the sort data no longer fits in <code class="varname">work_mem</code>,
        switch to a batch sorting algorithm that uses more output streams
        than before.
       </p></li><li class="listitem"><p>
        Improve performance and reduce memory consumption of in-memory
        sorts (Ronan Dunklau, David Rowley, Thomas Munro, John Naylor)
       </p></li><li class="listitem"><p>
        Allow <acronym class="acronym">WAL</acronym> <a class="link" href="runtime-config-wal.html#GUC-FULL-PAGE-WRITES">full page writes</a> to use
        LZ4 and Zstandard compression (Andrey Borodin, Justin Pryzby)
       </p><p>
        This is controlled by the <a class="link" href="runtime-config-wal.html#GUC-WAL-COMPRESSION"><code class="varname">wal_compression</code></a>
        server setting.
       </p></li><li class="listitem"><p>
        Add support for writing <acronym class="acronym">WAL</acronym>
        using <a class="link" href="runtime-config-wal.html#GUC-WAL-SYNC-METHOD">direct I/O</a> on
        macOS (Thomas Munro)
       </p><p>
        This only works if <code class="literal">max_wal_senders = 0</code>
        and <code class="literal">wal_level = minimal</code>.
       </p></li><li class="listitem"><p>
        Allow <a class="link" href="routine-vacuuming.html" title="25.1. Routine Vacuuming">vacuum</a> to be more
        aggressive in setting the oldest frozen and multi transaction id
        (Peter Geoghegan)
       </p></li><li class="listitem"><p>
        Allow a query referencing multiple <a class="link" href="ddl-foreign-data.html" title="5.12. Foreign Data">foreign tables</a> to perform
        parallel foreign table scans in more cases (Andrey Lepikhov,
        Etsuro Fujita)
       </p></li><li class="listitem"><p>
        Improve the performance of <a class="link" href="functions-window.html" title="9.22. Window Functions">window
        functions</a> that use <code class="function">row_number()</code>,
        <code class="function">rank()</code>, <code class="function">dense_rank()</code> and
        <code class="function">count()</code>
        (David Rowley)
       </p></li><li class="listitem"><p>
        Improve the performance of spinlocks on high-core-count ARM64
        systems (Geoffrey Blake)
       </p></li></ul></div></div><div class="sect4" id="id-1.11.6.9.5.3.7"><div class="titlepage"><div><div><h5 class="title">E.5.3.1.5. Monitoring</h5></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
        Enable default logging of checkpoints and slow autovacuum
        operations (Bharath Rupireddy)
       </p><p>
        This changes the default of <a class="link" href="runtime-config-logging.html#GUC-LOG-CHECKPOINTS"><code class="varname">log_checkpoints</code></a>
        to <code class="literal">on</code> and that of <a class="link" href="runtime-config-logging.html#GUC-LOG-AUTOVACUUM-MIN-DURATION"><code class="varname">log_autovacuum_min_duration</code></a>
        to 10 minutes.  This will cause even an idle server to generate
        some log output, which might cause problems on
        resource-constrained servers without log file rotation.  These
        defaults should be changed in such cases.
       </p></li><li class="listitem"><p>
        Generate progress messages in the server log during slow server
        starts (Nitin Jadhav, Robert Haas)
       </p><p>
        The messages report the cause of the delay.  The time interval for
        notification is controlled by the new server variable <a class="link" href="runtime-config-logging.html#GUC-LOG-STARTUP-PROGRESS-INTERVAL"><code class="varname">log_startup_progress_interval</code></a>.
       </p></li><li class="listitem"><p>
        Store <a class="link" href="monitoring-stats.html" title="28.2. The Cumulative Statistics System">cumulative statistics
        system</a> data in shared memory (Kyotaro Horiguchi, Andres
        Freund, Melanie Plageman)
       </p><p>
        Previously this data was sent to a statistics collector process
        via <acronym class="acronym">UDP</acronym> packets, and could only be read by
        sessions after transferring it via the file system.  There is no
        longer a separate statistics collector process.
       </p></li><li class="listitem"><p>
        Add additional information to <code class="command">VACUUM VERBOSE</code>
        and autovacuum logging messages (Peter Geoghegan)
       </p></li><li class="listitem"><p>
        Add <a class="link" href="sql-explain.html" title="EXPLAIN"><code class="command">EXPLAIN
        (BUFFERS)</code></a> output for temporary file block I/O
        (Masahiko Sawada)
       </p></li><li class="listitem"><p>
        Allow <a class="link" href="runtime-config-logging.html#GUC-LOG-DESTINATION">log output</a> in
        <acronym class="acronym">JSON</acronym> format (Sehrope Sarkuni, Michael Paquier)
       </p><p>
        The new setting is <code class="literal">log_destination = jsonlog</code>.
       </p></li><li class="listitem"><p>
        Allow <a class="link" href="monitoring-stats.html#MONITORING-STATS-FUNCS-TABLE" title="Table 28.34. Additional Statistics Functions"><code class="function">pg_stat_reset_single_table_counters()</code></a>
        to reset the counters of relations shared across all databases
        (Sadhuprasad Patro)
       </p></li><li class="listitem"><p>
        Add <a class="link" href="monitoring-stats.html#WAIT-EVENT-TABLE" title="Table 28.4. Wait Event Types">wait events</a> for local
        shell commands (Fujii Masao)
       </p><p>
        The new wait events are used when calling
        <code class="varname">archive_command</code>,
        <code class="varname">archive_cleanup_command</code>,
        <code class="varname">restore_command</code> and
        <code class="varname">recovery_end_command</code>.
       </p></li></ul></div></div><div class="sect4" id="id-1.11.6.9.5.3.8"><div class="titlepage"><div><div><h5 class="title">E.5.3.1.6. Privileges</h5></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
        Allow table accesses done by
        a <a class="link" href="sql-createview.html" title="CREATE VIEW">view</a> to optionally be
        controlled by privileges of the view's caller (Christoph Heiss)
       </p><p>
        Previously, view accesses were always treated as being done by the
        view's owner.  That's still the default.
       </p></li><li class="listitem"><p>
        Allow members of the <a class="link" href="predefined-roles.html#PREDEFINED-ROLES-TABLE" title="Table 22.1. Predefined Roles"><code class="literal">pg_write_server_files</code></a>
        predefined role to perform server-side base backups (Dagfinn
        Ilmari Mannsåker)
       </p><p>
        Previously only superusers could perform such backups.
       </p></li><li class="listitem"><p>
        Allow <a class="link" href="sql-grant.html" title="GRANT"><code class="command">GRANT</code></a>
        to grant permissions to change individual server variables via
        <code class="command">SET</code> and <code class="command">ALTER SYSTEM</code>
        (Mark Dilger)
       </p><p>
        The new function <code class="function">has_parameter_privilege()</code>
        reports on this privilege.
       </p></li><li class="listitem"><p>
        Add predefined role <a class="link" href="predefined-roles.html#PREDEFINED-ROLES-TABLE" title="Table 22.1. Predefined Roles"><code class="literal">pg_checkpoint</code></a>
        that allows members to run <code class="command">CHECKPOINT</code>
        (Jeff Davis)
       </p><p>
        Previously checkpoints could only be run by superusers.
       </p></li><li class="listitem"><p>
        Allow members of the <a class="link" href="predefined-roles.html#PREDEFINED-ROLES-TABLE" title="Table 22.1. Predefined Roles"><code class="literal">pg_read_all_stats</code></a>
        predefined role to access the views <a class="link" href="view-pg-backend-memory-contexts.html" title="54.4. pg_backend_memory_contexts"><code class="structname">pg_backend_memory_contexts</code></a>
        and <a class="link" href="view-pg-shmem-allocations.html" title="54.26. pg_shmem_allocations"><code class="structname">pg_shmem_allocations</code></a>
        (Bharath Rupireddy)
       </p><p>
        Previously these views could only be accessed by superusers.
       </p></li><li class="listitem"><p>
        Allow <a class="link" href="sql-grant.html" title="GRANT"><code class="command">GRANT</code></a>
        to grant permissions on <a class="link" href="functions-admin.html#FUNCTIONS-ADMIN-SIGNAL" title="9.27.2. Server Signaling Functions"><code class="function">pg_log_backend_memory_contexts()</code></a>
        (Jeff Davis)
       </p><p>
        Previously this function could only be run by superusers.
       </p></li></ul></div></div><div class="sect4" id="id-1.11.6.9.5.3.9"><div class="titlepage"><div><div><h5 class="title">E.5.3.1.7. Server Configuration</h5></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
        Add server variable <a class="link" href="runtime-config-preset.html#GUC-SHARED-MEMORY-SIZE"><code class="varname">shared_memory_size</code></a>
        to report the size of allocated shared memory (Nathan Bossart)
       </p></li><li class="listitem"><p>
        Add server variable <a class="link" href="runtime-config-preset.html#GUC-SHARED-MEMORY-SIZE-IN-HUGE-PAGES"><code class="varname">shared_memory_size_in_huge_pages</code></a>
        to report the number of huge memory pages required (Nathan Bossart)
       </p><p>
        This is only supported on Linux.
       </p></li><li class="listitem"><p>
        Honor server variable <a class="link" href="runtime-config-client.html#GUC-SHARED-PRELOAD-LIBRARIES"><code class="varname">shared_preload_libraries</code></a>
        in single-user mode (Jeff Davis)
       </p><p>
        This change supports use
        of <code class="varname">shared_preload_libraries</code> to load custom
        access methods and WAL resource managers, which would be essential
        for database access even in single-user mode.
       </p></li><li class="listitem"><p>
        On Solaris, make the default setting of <a class="link" href="runtime-config-resource.html#GUC-DYNAMIC-SHARED-MEMORY-TYPE"><code class="varname">dynamic_shared_memory_type</code></a>
        be <code class="literal">sysv</code> (Thomas Munro)
       </p><p>
        The previous default choice, <code class="literal">posix</code>, can result
        in spurious failures on this platform.
       </p></li><li class="listitem"><p>
        Allow <a class="link" href="app-postgres.html" title="postgres"><code class="command">postgres
        -C</code></a> to properly report runtime-computed values
        (Nathan Bossart)
       </p><p>
        Previously runtime-computed values <a class="link" href="runtime-config-preset.html#GUC-DATA-CHECKSUMS"><code class="varname">data_checksums</code></a>,
        <a class="link" href="runtime-config-preset.html#GUC-WAL-SEGMENT-SIZE"><code class="varname">wal_segment_size</code></a>,
        and <a class="link" href="runtime-config-preset.html#GUC-DATA-DIRECTORY-MODE"><code class="varname">data_directory_mode</code></a>
        would report values that would not be accurate on the running
        server.  However, this does not work on a running server.
       </p></li></ul></div></div></div><div class="sect3" id="id-1.11.6.9.5.4"><div class="titlepage"><div><div><h4 class="title">E.5.3.2. Streaming Replication and Recovery</h4></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
       Add support for LZ4 and Zstandard compression of server-side <a class="link" href="continuous-archiving.html#BACKUP-BASE-BACKUP" title="26.3.2. Making a Base Backup">base backups</a> (Jeevan Ladhe,
       Robert Haas)
      </p></li><li class="listitem"><p>
       Run the checkpointer and bgwriter processes during crash recovery
       (Thomas Munro)
      </p><p>
       This helps to speed up long crash recoveries.
      </p></li><li class="listitem"><p>
       Allow <acronym class="acronym">WAL</acronym> processing to pre-fetch needed file
       contents (Thomas Munro)
      </p><p>
       This is controlled by the server variable <a class="link" href="runtime-config-wal.html#GUC-RECOVERY-PREFETCH"><code class="varname">recovery_prefetch</code></a>.
      </p></li><li class="listitem"><p>
       Allow archiving via loadable modules (Nathan Bossart)
      </p><p>
       Previously, archiving was only done by calling shell commands.
       The new server variable <a class="link" href="runtime-config-wal.html#GUC-ARCHIVE-LIBRARY"><code class="varname">archive_library</code></a>
       can be set to specify a library to be called for archiving.
      </p></li><li class="listitem"><p>
       No longer require <a class="link" href="protocol-replication.html" title="55.4. Streaming Replication Protocol"><code class="literal">IDENTIFY_SYSTEM</code></a>
       to be run before <code class="literal">START_REPLICATION</code> (Jeff Davis)
      </p></li></ul></div><div class="sect4" id="id-1.11.6.9.5.4.3"><div class="titlepage"><div><div><h5 class="title">E.5.3.2.1. <a class="link" href="logical-replication.html" title="Chapter 31. Logical Replication">Logical Replication</a></h5></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
        Allow <a class="link" href="sql-createpublication.html" title="CREATE PUBLICATION">publication</a> of
        all tables in a schema (Vignesh C, Hou Zhijie, Amit Kapila)
       </p><p>
        For example, this syntax is now supported: <code class="literal">CREATE
        PUBLICATION pub1 FOR TABLES IN SCHEMA s1,s2</code>.
        <code class="command">ALTER PUBLICATION</code> supports a similar syntax.
        Tables added later to the listed schemas will also be replicated.
       </p></li><li class="listitem"><p>
        Allow publication content to be filtered using a
        <code class="literal">WHERE</code> clause (Hou Zhijie, Euler Taveira,
        Peter Smith, Ajin Cherian, Tomas Vondra, Amit Kapila)
       </p><p>
        Rows not satisfying the <code class="literal">WHERE</code> clause are not
        published.
       </p></li><li class="listitem"><p>
        Allow publication content to
        be restricted to specific columns (Tomas Vondra, Álvaro Herrera,
        Rahila Syed)
       </p></li><li class="listitem"><p>
        Allow skipping of transactions on a subscriber using <a class="link" href="sql-altersubscription.html" title="ALTER SUBSCRIPTION"><code class="command">ALTER SUBSCRIPTION
        ... SKIP</code></a> (Masahiko Sawada)
       </p></li><li class="listitem"><p>
        Add support for prepared (two-phase) transactions to logical
        replication (Peter Smith, Ajin Cherian, Amit Kapila, Nikhil
        Sontakke, Stas Kelvich)
       </p><p>
        The new <a class="link" href="protocol-replication.html" title="55.4. Streaming Replication Protocol"><code class="literal">CREATE_REPLICATION_SLOT</code></a>
        option is called <code class="literal">TWO_PHASE</code>.
        <span class="application">pg_recvlogical</span> now supports a new
        <code class="option">--two-phase</code> option during slot creation.
       </p></li><li class="listitem"><p>
        Prevent logical replication of empty transactions (Ajin Cherian,
        Hou Zhijie, Euler Taveira)
       </p><p>
        Previously, publishers would send empty transactions to
        subscribers if subscribed tables were not modified.
       </p></li><li class="listitem"><p>
        Add <acronym class="acronym">SQL</acronym> functions to monitor the directory
        contents of logical replication slots (Bharath Rupireddy)
       </p><p>
        The new functions are <a class="link" href="functions-admin.html#FUNCTIONS-ADMIN-GENFILE-TABLE" title="Table 9.99. Generic File Access Functions"><code class="function">pg_ls_logicalsnapdir()</code></a>,
        <code class="function">pg_ls_logicalmapdir()</code>, and
        <code class="function">pg_ls_replslotdir()</code>.  They can be run by
        members of the predefined <code class="literal">pg_monitor</code> role.
       </p></li><li class="listitem"><p>
        Allow subscribers to stop the application of logical replication changes on error
        (Osumi Takamichi, Mark Dilger)
       </p><p>
        This is enabled with the subscriber option <a class="link" href="sql-createsubscription.html" title="CREATE SUBSCRIPTION"><code class="literal">disable_on_error</code></a>
        and avoids possible infinite error loops during stream application.
       </p></li><li class="listitem"><p>
        Adjust subscriber server variables to match the publisher so
        datetime and float8 values are interpreted consistently (Japin Li)
       </p><p>
        Some publishers might be relying on inconsistent behavior.
       </p></li><li class="listitem"><p>
        Add system view <a class="link" href="monitoring-stats.html#MONITORING-PG-STAT-SUBSCRIPTION-STATS" title="28.2.9. pg_stat_subscription_stats"><code class="structname">pg_stat_subscription_stats</code></a>
        to report on subscriber activity (Masahiko Sawada)
       </p><p>
        The new function <a class="link" href="monitoring-stats.html#MONITORING-STATS-FUNCTIONS" title="28.2.24. Statistics Functions"><code class="function">pg_stat_reset_subscription_stats()</code></a>
        allows resetting these statistics counters.
       </p></li><li class="listitem"><p>
        Suppress duplicate entries in the <a class="link" href="view-pg-publication-tables.html" title="54.17. pg_publication_tables"><code class="structname">pg_publication_tables</code></a>
        system view (Hou Zhijie)
       </p><p>
        In some cases a partition could appear more than once.
       </p></li></ul></div></div></div><div class="sect3" id="id-1.11.6.9.5.5"><div class="titlepage"><div><div><h4 class="title">E.5.3.3. Utility Commands</h4></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
       Add <acronym class="acronym">SQL</acronym> <a class="link" href="sql-merge.html" title="MERGE"><code class="command">MERGE</code></a>
       command to adjust one table to match another (Simon Riggs, Pavan
       Deolasee, Álvaro Herrera, Amit Langote)
      </p><p>
       This is similar to <code class="command">INSERT ... ON CONFLICT</code>
       but more batch-oriented.
      </p></li><li class="listitem"><p>
       Add support for <code class="literal">HEADER</code> option in <a class="link" href="sql-copy.html" title="COPY"><code class="command">COPY</code></a> text format
       (Rémi Lapeyre)
      </p><p>
       The new option causes the column names to be output, and optionally
       verified on input.
      </p></li><li class="listitem"><p>
       Add new <acronym class="acronym">WAL</acronym>-logged method for <a class="link" href="sql-createdatabase.html" title="CREATE DATABASE">database creation</a> (Dilip Kumar)
      </p><p>
       This is the new default method for copying the template database,
       as it avoids the need for checkpoints during database creation.
       However, it might be slow if the template database is large, so
       the old method is still available.
      </p></li><li class="listitem"><p>
       Allow <a class="link" href="sql-createdatabase.html" title="CREATE DATABASE"><code class="command">CREATE
       DATABASE</code></a> to set the database <acronym class="acronym">OID</acronym>
       (Shruthi Gowda, Antonin Houska)
      </p></li><li class="listitem"><p>
       Prevent <a class="link" href="sql-dropdatabase.html" title="DROP DATABASE"><code class="command">DROP
       DATABASE</code></a>, <a class="link" href="sql-droptablespace.html" title="DROP TABLESPACE"><code class="command">DROP
       TABLESPACE</code></a>, and <a class="link" href="sql-alterdatabase.html" title="ALTER DATABASE"><code class="command">ALTER DATABASE SET
       TABLESPACE</code></a> from occasionally failing during
       concurrent use on Windows (Thomas Munro)
      </p></li><li class="listitem"><p>
       Allow foreign key <a class="link" href="ddl-constraints.html#DDL-CONSTRAINTS-FK" title="5.4.5. Foreign Keys"><code class="literal">ON
       DELETE SET</code></a> actions to affect only specified columns
       (Paul Martinez)
      </p><p>
       Previously, all of the columns in the foreign key were always
       affected.
      </p></li><li class="listitem"><p>
       Allow <a class="link" href="sql-altertable.html" title="ALTER TABLE"><code class="command">ALTER
       TABLE</code></a> to modify a table's <code class="literal">ACCESS
       METHOD</code> (Justin Pryzby, Jeff Davis)
      </p></li><li class="listitem"><p>
       Properly call object access hooks when <a class="link" href="sql-altertable.html" title="ALTER TABLE"><code class="command">ALTER TABLE</code></a>
       causes table rewrites (Michael Paquier)
      </p></li><li class="listitem"><p>
       Allow creation of unlogged <a class="link" href="sql-createsequence.html" title="CREATE SEQUENCE">sequences</a> (Peter Eisentraut)
      </p></li><li class="listitem"><p>
       Track dependencies on individual columns in the results of
       functions returning composite types (Tom Lane)
      </p><p>
       Previously, if a view or rule contained a reference to a specific
       column within the result of a composite-returning function, that
       was not noted as a dependency; the view or rule was only considered
       to depend on the composite type as a whole.  This meant that
       dropping the individual column would be allowed, causing problems
       in later use of the view or rule.  The column-level dependency is
       now also noted, so that dropping such a column will be rejected
       unless the view is changed or dropped.
      </p></li></ul></div></div><div class="sect3" id="id-1.11.6.9.5.6"><div class="titlepage"><div><div><h4 class="title">E.5.3.4. Data Types</h4></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
       Allow the scale of
       a <a class="link" href="datatype-numeric.html" title="8.1. Numeric Types"><code class="type">numeric</code></a>
       value to be negative, or greater than its precision (Dean Rasheed,
       Tom Lane)
      </p><p>
       This allows rounding of values to the left of the decimal point,
       e.g., <code class="literal">'1234'::numeric(4, -2)</code> returns 1200.
      </p></li><li class="listitem"><p>
       Improve overflow detection when casting values to <a class="link" href="datatype-datetime.html" title="8.5. Date/Time Types">interval</a> (Joe Koshakow)
      </p></li><li class="listitem"><p>
      Change the I/O format of type <code class="type">"char"</code> for non-ASCII
      characters (Tom Lane)
     </p></li><li class="listitem"><p>
       Update the display width information of modern Unicode characters,
       like emojis (Jacob Champion)
      </p><p>
       Also update from Unicode 5.0 to 14.0.0.  There is now an automated
       way to keep Postgres updated with Unicode releases.
      </p></li></ul></div></div><div class="sect3" id="id-1.11.6.9.5.7"><div class="titlepage"><div><div><h4 class="title">E.5.3.5. Functions</h4></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
       Add multirange input to <a class="link" href="functions-aggregate.html#FUNCTIONS-AGGREGATE-TABLE" title="Table 9.58. General-Purpose Aggregate Functions"><code class="function">range_agg()</code></a>
       (Paul Jungwirth)
      </p></li><li class="listitem"><p>
       Add <a class="link" href="tutorial-agg.html" title="2.7. Aggregate Functions"><code class="function">MIN()</code></a>
       and <code class="function">MAX()</code> aggregates for the <a class="link" href="datatype-numeric.html#DATATYPE-INT" title="8.1.1. Integer Types"><code class="type">xid8</code></a> data type (Ken Kato)
      </p></li><li class="listitem"><p>
       Add regular expression functions for compatibility with other
       relational systems (Gilles Darold, Tom Lane)
      </p><p>
       The new functions are <a class="link" href="functions-string.html#FUNCTIONS-STRING-OTHER" title="Table 9.10. Other String Functions and Operators"><code class="function">regexp_count()</code></a>,
       <code class="function">regexp_instr()</code>,
       <code class="function">regexp_like()</code>, and
       <code class="function">regexp_substr()</code>.  Some new optional arguments
       were also added to <code class="function">regexp_replace()</code>.
      </p></li><li class="listitem"><p>
       Add the ability to compute the distance between <a class="link" href="datatype-geometric.html#DATATYPE-POLYGON" title="8.8.6. Polygons"><code class="type">polygons</code></a> (Tom Lane)
      </p></li><li class="listitem"><p>
       Add <a class="link" href="functions-formatting.html#FUNCTIONS-FORMATTING-TABLE" title="Table 9.26. Formatting Functions"><code class="function">to_char()</code></a>
       format codes <code class="literal">of</code>, <code class="literal">tzh</code>, and
       <code class="literal">tzm</code> (Nitin Jadhav)
      </p><p>
       The upper-case equivalents of these were already supported.
      </p></li><li class="listitem"><p>
       When applying <a class="link" href="functions-datetime.html#FUNCTIONS-DATETIME-ZONECONVERT" title="9.9.4. AT TIME ZONE"><code class="literal">AT
       TIME ZONE</code></a> to a <code class="type">time with time zone</code>
       value, use the transaction start time rather than wall clock time
       to determine whether DST applies (Aleksander Alekseev, Tom Lane)
      </p><p>
       This allows the conversion to be considered stable rather than
       volatile, and it saves a kernel call per invocation.
      </p></li><li class="listitem"><p>
       Ignore NULL array elements in <a class="link" href="functions-textsearch.html#TEXTSEARCH-FUNCTIONS-TABLE" title="Table 9.43. Text Search Functions"><code class="function">ts_delete()</code></a> and
       <code class="function">setweight()</code> functions with array arguments
       (Jean-Christophe Arnu)
      </p><p>
       These functions effectively ignore empty-string array elements
       (since those could never match a valid lexeme).  It seems
       consistent to let them ignore NULL elements too, instead of
       failing.
      </p></li><li class="listitem"><p>
       Add support for petabyte units to <a class="link" href="functions-admin.html#FUNCTIONS-ADMIN-DBSIZE" title="Table 9.94. Database Object Size Functions"><code class="function">pg_size_pretty()</code></a>
       and <code class="function">pg_size_bytes()</code> (David Christensen)
      </p></li><li class="listitem"><p>
       Change <a class="link" href="functions-event-triggers.html#PG-EVENT-TRIGGER-DDL-COMMAND-END-FUNCTIONS" title="9.29.1. Capturing Changes at Command End"><code class="function">pg_event_trigger_ddl_commands()</code></a>
       to output references to other sessions' temporary schemas using the
       actual schema name (Tom Lane)
      </p><p>
       Previously this function reported all temporary schemas as
       <code class="literal">pg_temp</code>, but it's misleading to use that for any
       but the current session's temporary schema.
      </p></li></ul></div></div><div class="sect3" id="id-1.11.6.9.5.8"><div class="titlepage"><div><div><h4 class="title">E.5.3.6. <a class="link" href="plpgsql.html" title="Chapter 43. PL/pgSQL — SQL Procedural Language">PL/pgSQL</a></h4></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
       Fix enforcement of PL/pgSQL variable <code class="literal">CONSTANT</code>
       markings (Tom Lane)
      </p><p>
       Previously, a variable could be used as a <a class="link" href="plpgsql-control-structures.html#PLPGSQL-STATEMENTS-CALLING-PROCEDURE" title="43.6.3. Calling a Procedure"><code class="command">CALL</code></a>
       output parameter or refcursor <code class="command">OPEN</code> variable
       despite being marked <code class="literal">CONSTANT</code>.
      </p></li></ul></div></div><div class="sect3" id="id-1.11.6.9.5.9"><div class="titlepage"><div><div><h4 class="title">E.5.3.7. <a class="link" href="libpq.html" title="Chapter 34. libpq — C Library">libpq</a></h4></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
       Allow <acronym class="acronym">IP</acronym> address matching against a server
       certificate's Subject Alternative Name (Jacob Champion)
      </p></li><li class="listitem"><p>
       Allow <code class="function">PQsslAttribute()</code> to report the
       <acronym class="acronym">SSL</acronym> library type without requiring a libpq
       connection (Jacob Champion)
      </p></li><li class="listitem"><p>
       Change query cancellations sent by the client to use the same
       <acronym class="acronym">TCP</acronym> settings as normal client connections
       (Jelte Fennema)
      </p><p>
       This allows configured <acronym class="acronym">TCP</acronym> timeouts to apply
       to query cancel connections.
      </p></li><li class="listitem"><p>
       Prevent libpq event callback failures from forcing an error result
       (Tom Lane)
      </p></li></ul></div></div><div class="sect3" id="id-1.11.6.9.5.10"><div class="titlepage"><div><div><h4 class="title">E.5.3.8. Client Applications</h4></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
       Allow <a class="link" href="pgbench.html" title="pgbench"><span class="application">pgbench</span></a> to
       retry after serialization and deadlock failures (Yugo Nagata,
       Marina Polyakova)
      </p></li></ul></div><div class="sect4" id="id-1.11.6.9.5.10.3"><div class="titlepage"><div><div><h5 class="title">E.5.3.8.1. <a class="xref" href="app-psql.html" title="psql"><span class="refentrytitle"><span class="application">psql</span></span></a></h5></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
        Improve performance
        of <span class="application">psql</span>'s <code class="command">\copy</code>
        command, by sending data in larger chunks (Heikki Linnakangas)
       </p></li><li class="listitem"><p>
        Add <code class="command">\dconfig</code> command to report server variables
        (Mark Dilger, Tom Lane)
       </p><p>
        This is similar to the server-side <code class="command">SHOW</code>
        command, but it can process patterns to show multiple variables
        conveniently.
       </p></li><li class="listitem"><p>
        Add <code class="command">\getenv</code> command
        to assign the value of an environment variable to a
        <span class="application">psql</span> variable (Tom Lane)
       </p></li><li class="listitem"><p>
        Add <code class="literal">+</code> option to the
        <code class="literal">\lo_list</code> and <code class="literal">\dl</code> commands to
        show large-object privileges (Pavel Luzanov)
       </p></li><li class="listitem"><p>
        Add a pager option for the <code class="command">\watch</code>
        command (Pavel Stehule, Thomas Munro)
       </p><p>
        This is only supported on Unix and is controlled by the
        <code class="envar">PSQL_WATCH_PAGER</code> environment variable.
       </p></li><li class="listitem"><p>
        Make <span class="application">psql</span> include intra-query double-hyphen
        comments in queries sent to the server (Tom Lane, Greg Nancarrow)
       </p><p>
        Previously such comments were removed from the query
        before being sent.  Double-hyphen comments that are before any
        query text are not sent, and are not recorded as separate
        <span class="application">psql</span> history entries.
       </p></li><li class="listitem"><p>
        Adjust <span class="application">psql</span> so
        that <span class="application">Readline</span>'s
        meta-<code class="literal">#</code> command will insert a double-hyphen
        comment marker (Tom Lane)
       </p><p>
        Previously a pound marker was inserted, unless the user had taken
        the trouble to configure a non-default comment marker.
       </p></li><li class="listitem"><p>
        Make <span class="application">psql</span> output all results when multiple
        queries are passed to the server at once (Fabien Coelho)
       </p><p>
        Previously, only the last query result was displayed.  The old
        behavior can be restored by setting
        the <code class="literal">SHOW_ALL_RESULTS</code> <span class="application">psql</span>
        variable to <code class="literal">off</code>.
       </p></li><li class="listitem"><p>
        After an error is detected
        in <code class="option">--single-transaction</code> mode, change the
        final <code class="command">COMMIT</code> command
        to <code class="command">ROLLBACK</code> only
        if <code class="varname">ON_ERROR_STOP</code> is set (Michael Paquier)
       </p><p>
        Previously, detection of an error in a <code class="option">-c</code> command
        or <code class="option">-f</code> script file would lead to
        issuing <code class="command">ROLLBACK</code> at the end, regardless of the
        value of <code class="varname">ON_ERROR_STOP</code>.
       </p></li><li class="listitem"><p>
        Improve <span class="application">psql</span>'s tab completion (Shinya
        Kato, Dagfinn Ilmari Mannsåker, Peter Smith, Koyu Tanigawa,
        Ken Kato, David Fetter, Haiying Tang, Peter Eisentraut, Álvaro
        Herrera, Tom Lane, Masahiko Sawada)
       </p></li><li class="listitem"><p>
        Limit support of <span class="application">psql</span>'s backslash
        commands to servers running <span class="productname">PostgreSQL</span>
        9.2 or later (Tom Lane)
       </p><p>
        Remove code that was only used when running with an older server.
        Commands that do not require any version-specific adjustments
        compared to 9.2 will still work.
       </p></li></ul></div></div><div class="sect4" id="id-1.11.6.9.5.10.4"><div class="titlepage"><div><div><h5 class="title">E.5.3.8.2. <a class="link" href="app-pgdump.html" title="pg_dump"><span class="application">pg_dump</span></a></h5></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
        Make <span class="application">pg_dump</span> dump
        <code class="literal">public</code> schema ownership changes and security
        labels (Noah Misch)
       </p></li><li class="listitem"><p>
        Improve performance of dumping databases with many objects
        (Tom Lane)
       </p><p>
        This will also improve the performance of <a class="link" href="pgupgrade.html" title="pg_upgrade"><span class="application">pg_upgrade</span></a>.
       </p></li><li class="listitem"><p>
        Improve parallel <span class="application">pg_dump</span>'s performance
        for tables with large <acronym class="acronym">TOAST</acronym> tables (Tom Lane)
       </p></li><li class="listitem"><p>
        Add dump/restore option <code class="option">--no-table-access-method</code>
        to force restore to only use the default table access method
        (Justin Pryzby)
       </p></li><li class="listitem"><p>
        Limit support of <span class="application">pg_dump</span> and <a class="link" href="app-pg-dumpall.html" title="pg_dumpall"><span class="application">pg_dumpall</span></a>
        to servers running <span class="productname">PostgreSQL</span> 9.2 or
        later (Tom Lane)
       </p></li></ul></div></div></div><div class="sect3" id="id-1.11.6.9.5.11"><div class="titlepage"><div><div><h4 class="title">E.5.3.9. Server Applications</h4></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
       Add new <a class="link" href="app-pgbasebackup.html" title="pg_basebackup"><span class="application">pg_basebackup</span></a>
       option <code class="option">--target</code> to control the base backup location
       (Robert Haas)
      </p><p>
       The new options are <code class="literal">server</code> to write the
       backup locally and <code class="literal">blackhole</code> to discard the
       backup (for testing).
      </p></li><li class="listitem"><p>
       Allow <span class="application">pg_basebackup</span> to do server-side
       gzip, LZ4, and Zstandard compression and client-side LZ4 and
       Zstandard compression of base backup files (Dipesh Pandit,
       Jeevan Ladhe)
      </p><p>
       Client-side <code class="literal">gzip</code> compression was already
       supported.
      </p></li><li class="listitem"><p>
       Allow <span class="application">pg_basebackup</span> to compress on
       the server side and decompress on the client side before storage
       (Dipesh Pandit)
      </p><p>
       This is accomplished by specifying compression on the server side
       and plain output format.
      </p></li><li class="listitem"><p>
       Allow <span class="application">pg_basebackup</span>'s
       <code class="option">--compress</code> option to control the compression
       location (server or client), compression method, and compression
       options (Michael Paquier, Robert Haas)
      </p></li><li class="listitem"><p>
       Add the LZ4 compression method to <a class="link" href="app-pgreceivewal.html" title="pg_receivewal"><span class="application">pg_receivewal</span></a>
       (Georgios Kokolatos)
      </p><p>
       This is enabled via <code class="literal">--compress=lz4</code> and requires
       binaries to be built using <code class="option">--with-lz4</code>.
      </p></li><li class="listitem"><p>
       Add additional capabilities to
       <span class="application">pg_receivewal</span>'s
       <code class="option">--compress</code> option (Georgios Kokolatos)
      </p></li><li class="listitem"><p>
       Improve <span class="application">pg_receivewal</span>'s ability to
       restart at the proper <acronym class="acronym">WAL</acronym> location (Ronan
       Dunklau)
      </p><p>
       Previously, <span class="application">pg_receivewal</span> would start
       based on the <acronym class="acronym">WAL</acronym> file stored in the local archive
       directory, or at the sending server's current <acronym class="acronym">WAL</acronym>
       flush location.  With this change, if the sending server is running
       Postgres 15 or later, the local archive directory is empty, and
       a replication slot is specified, the replication slot's restart
       point will be used.
      </p></li><li class="listitem"><p>
       Add <a class="link" href="app-pgrewind.html" title="pg_rewind"><span class="application">pg_rewind</span></a>
       option <code class="option">--config-file</code> to simplify use when server
       configuration files are stored outside the data directory (Gunnar
       Bluth)
      </p></li></ul></div><div class="sect4" id="id-1.11.6.9.5.11.3"><div class="titlepage"><div><div><h5 class="title">E.5.3.9.1. <a class="link" href="pgupgrade.html" title="pg_upgrade"><span class="application">pg_upgrade</span></a></h5></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
        Store <span class="application">pg_upgrade</span>'s log and
        temporary files in a subdirectory of the new cluster called
        <code class="filename">pg_upgrade_output.d</code> (Justin Pryzby)
       </p><p>
        Previously such files were left in the current directory,
        requiring manual cleanup.  Now they are automatically removed on
        successful completion of <span class="application">pg_upgrade</span>.
       </p></li><li class="listitem"><p>
        Disable default status reporting during
        <span class="application">pg_upgrade</span> operation if the output is
        not a terminal (Andres Freund)
       </p><p>
        The status reporting output can be enabled for non-tty usage by
        using <code class="option">--verbose</code>.
       </p></li><li class="listitem"><p>
        Make <span class="application">pg_upgrade</span> report all databases
        with invalid connection settings (Jeevan Ladhe)
       </p><p>
        Previously only the first database with an invalid connection
        setting was reported.
       </p></li><li class="listitem"><p>
        Make <span class="application">pg_upgrade</span> preserve tablespace
        and database OIDs, as well as relation relfilenode numbers
        (Shruthi Gowda, Antonin Houska)
       </p></li><li class="listitem"><p>
        Add a <code class="option">--no-sync</code> option to
        <span class="application">pg_upgrade</span> (Michael Paquier)
       </p><p>
        This is recommended only for testing.
       </p></li><li class="listitem"><p>
        Limit support of <span class="application">pg_upgrade</span> to old
        servers running <span class="productname">PostgreSQL</span> 9.2 or later
        (Tom Lane)
       </p></li></ul></div></div><div class="sect4" id="id-1.11.6.9.5.11.4"><div class="titlepage"><div><div><h5 class="title">E.5.3.9.2. <a class="link" href="pgwaldump.html" title="pg_waldump"><span class="application">pg_waldump</span></a></h5></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
        Allow <span class="application">pg_waldump</span> output to be filtered by
        relation file node, block number, fork number, and full page images
        (David Christensen, Thomas Munro)
       </p></li><li class="listitem"><p>
        Make <span class="application">pg_waldump</span> report statistics
        before an interrupted exit (Bharath Rupireddy)
       </p><p>
        For example, issuing a control-C in a terminal running
        <code class="command">pg_waldump --stats --follow</code> will report the
        current statistics before exiting.  This does not work on Windows.
       </p></li><li class="listitem"><p>
        Improve descriptions of some transaction <acronym class="acronym">WAL</acronym>
        records reported by <span class="application">pg_waldump</span>
        (Masahiko Sawada, Michael Paquier)
       </p></li><li class="listitem"><p>
        Allow <span class="application">pg_waldump</span> to dump information
        about multiple resource managers (Heikki Linnakangas)
       </p><p>
        This is enabled by specifying the <code class="option">--rmgr</code> option
        multiple times.
       </p></li></ul></div></div></div><div class="sect3" id="id-1.11.6.9.5.12"><div class="titlepage"><div><div><h4 class="title">E.5.3.10. Documentation</h4></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
       Add documentation for <a class="link" href="functions-info.html#FUNCTIONS-INFO-CATALOG-TABLE" title="Table 9.71. System Catalog Information Functions"><code class="function">pg_encoding_to_char()</code></a>
       and <code class="function">pg_char_to_encoding()</code> (Ian Lawrence
       Barwick)
      </p></li><li class="listitem"><p>
       Document the <a class="link" href="functions-string.html#FUNCTIONS-STRING-OTHER" title="Table 9.10. Other String Functions and Operators"><code class="literal">^@</code></a>
       starts-with operator (Tom Lane)
      </p></li></ul></div></div><div class="sect3" id="id-1.11.6.9.5.13"><div class="titlepage"><div><div><h4 class="title">E.5.3.11. Source Code</h4></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
       Add support for continuous integration testing using cirrus-ci
       (Andres Freund, Thomas Munro, Melanie Plageman)
      </p></li><li class="listitem"><p>
       Add configure option <a class="link" href="install-procedure.html#CONFIGURE-OPTIONS-FEATURES" title="17.4.1.2. PostgreSQL Features"><code class="option">--with-zstd</code></a>
       to enable Zstandard builds (Jeevan Ladhe, Robert Haas, Michael
       Paquier)
      </p></li><li class="listitem"><p>
       Add an ABI identifier field to the magic block in loadable
       libraries, allowing
       non-community <span class="productname">PostgreSQL</span> distributions
       to identify libraries that are not compatible with other builds
       (Peter Eisentraut)
      </p><p>
       An ABI field mismatch will generate an error at load time.
      </p></li><li class="listitem"><p>
       Create a new <a class="link" href="catalog-pg-type.html" title="53.64. pg_type"><code class="structfield">pg_type.typcategory</code></a>
       value for <code class="type">"char"</code> (Tom Lane)
      </p><p>
       Some other internal-use-only types have also been assigned to this
       category.
      </p></li><li class="listitem"><p>
       Add new protocol message <a class="link" href="protocol-replication.html#PROTOCOL-REPLICATION-BASE-BACKUP"><code class="literal">TARGET</code></a>
       to specify a new <code class="command">COPY</code> method to be used for base
       backups (Robert Haas)
      </p><p>
       <a class="link" href="app-pgbasebackup.html" title="pg_basebackup"><span class="application">pg_basebackup</span></a>
       now uses this method.
      </p></li><li class="listitem"><p>
       Add new protocol message <a class="link" href="protocol-replication.html#PROTOCOL-REPLICATION-BASE-BACKUP"><code class="literal">COMPRESSION</code></a>
       and <code class="literal">COMPRESSION_DETAIL</code> to specify the compression
       method and options (Robert Haas)
      </p></li><li class="listitem"><p>
       Remove server support for old <code class="literal">BASE_BACKUP</code>
       command syntax and base backup protocol (Robert Haas)
      </p></li><li class="listitem"><p>
       Add support for extensions to set custom backup targets (Robert
       Haas)
      </p></li><li class="listitem"><p>
       Allow extensions to define custom <acronym class="acronym">WAL</acronym>
       resource managers (Jeff Davis)
      </p></li><li class="listitem"><p>
       Add function <a class="link" href="functions-info.html#FUNCTIONS-INFO-CATALOG-TABLE" title="Table 9.71. System Catalog Information Functions"><code class="function">pg_settings_get_flags()</code></a>
       to get the flags of server variables (Justin Pryzby)
      </p></li><li class="listitem"><p>
       On Windows, export all the server's global variables using
       <code class="literal">PGDLLIMPORT</code> markers (Robert Haas)
      </p><p>
       Previously, only specific variables were accessible to extensions
       on Windows.
      </p></li><li class="listitem"><p>
       Require GNU <span class="application">make</span> version 3.81 or later
       to build <span class="productname">PostgreSQL</span> (Tom Lane)
      </p></li><li class="listitem"><p>
       Require OpenSSL to build the <a class="link" href="pgcrypto.html" title="F.28. pgcrypto"><span class="application">pgcrypto</span></a>
       extension (Peter Eisentraut)
      </p></li><li class="listitem"><p>
       Require <span class="application">Perl</span>
       version 5.8.3 or later (Dagfinn Ilmari Mannsåker)
      </p></li><li class="listitem"><p>
       Require <span class="application">Python</span>
       version 3.2 or later (Andres Freund)
      </p></li></ul></div></div><div class="sect3" id="id-1.11.6.9.5.14"><div class="titlepage"><div><div><h4 class="title">E.5.3.12. Additional Modules</h4></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
       Allow <a class="link" href="amcheck.html" title="F.2. amcheck"><span class="application">amcheck</span></a> to
       check sequences (Mark Dilger)
      </p></li><li class="listitem"><p>
       Improve <span class="application">amcheck</span> sanity checks for
       <acronym class="acronym">TOAST</acronym> tables (Mark Dilger)
      </p></li><li class="listitem"><p>
       Add new module <span class="application"><a class="link" href="basebackup-to-shell.html" title="F.5. basebackup_to_shell">basebackup_to_shell</a></span>
       as an example of a custom backup target (Robert Haas)
      </p></li><li class="listitem"><p>
       Add new module <a class="link" href="basic-archive.html" title="F.6. basic_archive"><span class="application">basic_archive</span></a>
       as an example of performing archiving via a library (Nathan Bossart)
      </p></li><li class="listitem"><p>
       Allow <a class="link" href="btree-gist.html" title="F.9. btree_gist"><span class="application">btree_gist</span></a>
       indexes on boolean columns (Emre Hasegeli)
      </p><p>
       These can be used for exclusion constraints.
      </p></li><li class="listitem"><p>
       Fix <a class="link" href="pageinspect.html" title="F.25. pageinspect"><span class="application">pageinspect</span></a>'s
       <code class="function">page_header()</code> to handle 32-kilobyte page sizes
       (Quan Zongliang)
      </p><p>
       Previously, improper negative values could be returned in certain
       cases.
      </p></li><li class="listitem"><p>
       Add counters for temporary file block I/O to <a class="link" href="pgstatstatements.html" title="F.32. pg_stat_statements"><span class="application">pg_stat_statements</span></a>
       (Masahiko Sawada)
      </p></li><li class="listitem"><p>
       Add <acronym class="acronym">JIT</acronym> counters to pg_stat_statements (Magnus
       Hagander)
      </p></li><li class="listitem"><p>
       Add new module <a class="link" href="pgwalinspect.html" title="F.37. pg_walinspect"><span class="application">pg_walinspect</span></a>
       (Bharath Rupireddy)
      </p><p>
       This gives <acronym class="acronym">SQL</acronym>-level output similar to <a class="link" href="pgwaldump.html" title="pg_waldump"><span class="application">pg_waldump</span></a>.
      </p></li><li class="listitem"><p>
       Indicate the permissive/enforcing state in <a class="link" href="sepgsql.html" title="F.40. sepgsql"><span class="application">sepgsql</span></a> log
       messages (Dave Page)
      </p></li></ul></div><div class="sect4" id="id-1.11.6.9.5.14.3"><div class="titlepage"><div><div><h5 class="title">E.5.3.12.1. <a class="link" href="postgres-fdw.html" title="F.38. postgres_fdw"><span class="application">postgres_fdw</span></a></h5></div></div></div><div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"><p>
        Allow postgres_fdw to push down <code class="literal">CASE</code> expressions
        (Alexander Pyhalov)
       </p></li><li class="listitem"><p>
        Add server variable
        <code class="varname">postgres_fdw.application_name</code> to control the
        application name of postgres_fdw connections (Hayato Kuroda)
       </p><p>
        Previously the remote session's <a class="link" href="runtime-config-logging.html#GUC-APPLICATION-NAME"><code class="varname">application_name</code></a>
        could only be set on the remote server or via a
        <span class="application">postgres_fdw</span> connection specification.
        <code class="varname">postgres_fdw.application_name</code> supports some
        escape sequences for customization, making it easier to tell such
        connections apart on the remote server.
       </p></li><li class="listitem"><p>
        Allow parallel commit on <span class="application">postgres_fdw</span>
        servers (Etsuro Fujita)
       </p><p>
        This is enabled with the <code class="literal">CREATE SERVER</code> option
        <code class="literal">parallel_commit</code>.
       </p></li></ul></div></div></div></div><div class="sect2" id="RELEASE-15-ACKNOWLEDGEMENTS"><div class="titlepage"><div><div><h3 class="title">E.5.4. Acknowledgments</h3></div></div></div><p>
    The following individuals (in alphabetical order) have contributed
    to this release as patch authors, committers, reviewers, testers,
    or reporters of issues.
   </p><table border="0" summary="Simple list" class="simplelist"><tr><td>Abhijit Menon-Sen</td></tr><tr><td>Adam Brusselback</td></tr><tr><td>Adam Mackler</td></tr><tr><td>Adrian Ho</td></tr><tr><td>Ahsan Hadi</td></tr><tr><td>Ajin Cherian</td></tr><tr><td>Alastair McKinley</td></tr><tr><td>Aleksander Alekseev</td></tr><tr><td>Ales Zeleny</td></tr><tr><td>Alex Kingsborough</td></tr><tr><td>Alex Kozhemyakin</td></tr><tr><td>Alexander Korotkov</td></tr><tr><td>Alexander Kukushkin</td></tr><tr><td>Alexander Lakhin</td></tr><tr><td>Alexander Nawratil</td></tr><tr><td>Alexander Pyhalov</td></tr><tr><td>Alexey Borzov</td></tr><tr><td>Alexey Ermakov</td></tr><tr><td>Aliaksandr Kalenik</td></tr><tr><td>Álvaro Herrera</td></tr><tr><td>Amit Kapila</td></tr><tr><td>Amit Khandekar</td></tr><tr><td>Amit Langote</td></tr><tr><td>Amul Sul</td></tr><tr><td>Anastasia Lubennikova</td></tr><tr><td>Anders Kaseorg</td></tr><tr><td>Andreas Dijkman</td></tr><tr><td>Andreas Grob</td></tr><tr><td>Andreas Seltenreich</td></tr><tr><td>Andrei Zubkov</td></tr><tr><td>Andres Freund</td></tr><tr><td>Andrew Alsup</td></tr><tr><td>Andrew Bille</td></tr><tr><td>Andrew Dunstan</td></tr><tr><td>Andrew Gierth</td></tr><tr><td>Andrew Kesper</td></tr><tr><td>Andrey Borodin</td></tr><tr><td>Andrey Lepikhov</td></tr><tr><td>Andrey Sokolov</td></tr><tr><td>Andy Fan</td></tr><tr><td>Anton Melnikov</td></tr><tr><td>Anton Voloshin</td></tr><tr><td>Antonin Houska</td></tr><tr><td>Arjan van de Ven</td></tr><tr><td>Arne Roland</td></tr><tr><td>Arthur Zakirov</td></tr><tr><td>Ashutosh Bapat</td></tr><tr><td>Ashutosh Sharma</td></tr><tr><td>Ashwin Agrawal</td></tr><tr><td>Asif Rehman</td></tr><tr><td>Asim Praveen</td></tr><tr><td>Atsushi Torikoshi</td></tr><tr><td>Aya Iwata</td></tr><tr><td>Bauyrzhan Sakhariyev</td></tr><tr><td>Benoit Lobréau</td></tr><tr><td>Bernd Dorn</td></tr><tr><td>Bertrand Drouvot</td></tr><tr><td>Bharath Rupireddy</td></tr><tr><td>Björn Harrtell</td></tr><tr><td>Boris Kolpackov</td></tr><tr><td>Boris Korzun</td></tr><tr><td>Brad Nicholson</td></tr><tr><td>Brar Piening</td></tr><tr><td>Bruce Momjian</td></tr><tr><td>Bruno da Silva</td></tr><tr><td>Bryn Llewellyn</td></tr><tr><td>Carl Sopchak</td></tr><tr><td>Cary Huang</td></tr><tr><td>Chapman Flack</td></tr><tr><td>Chen Jiaoqian</td></tr><tr><td>Chris Bandy</td></tr><tr><td>Chris Lowder</td></tr><tr><td>Christian Quest</td></tr><tr><td>Christoph Berg</td></tr><tr><td>Christoph Heiss</td></tr><tr><td>Christophe Pettus</td></tr><tr><td>Christopher Painter-Wakefield</td></tr><tr><td>Claudio Freire</td></tr><tr><td>Clemens Zeidler</td></tr><tr><td>Corey Huinker</td></tr><tr><td>Dag Lem</td></tr><tr><td>Dagfinn Ilmari Mannsåker</td></tr><tr><td>Dan Kubb</td></tr><tr><td>Daniel Cherniy</td></tr><tr><td>Daniel Gustafsson</td></tr><tr><td>Daniel Polski</td></tr><tr><td>Daniel Vérité</td></tr><tr><td>Daniel Westermann</td></tr><tr><td>Daniele Varrazzo</td></tr><tr><td>Daniil Anisimov</td></tr><tr><td>Danny Shemesh</td></tr><tr><td>Darafei Praliaskouski</td></tr><tr><td>Daria Lepikhova</td></tr><tr><td>Dave Cramer</td></tr><tr><td>Dave Page</td></tr><tr><td>David Christensen</td></tr><tr><td>David Fetter</td></tr><tr><td>David G. Johnston</td></tr><tr><td>David Rowley</td></tr><tr><td>David Steele</td></tr><tr><td>David Zhang</td></tr><tr><td>Dean Rasheed</td></tr><tr><td>Dian Fay</td></tr><tr><td>Dilip Kumar</td></tr><tr><td>Dipesh Pandit</td></tr><tr><td>Dmitry Dolgov</td></tr><tr><td>Dmitry Koval</td></tr><tr><td>Dmitry Marakasov</td></tr><tr><td>Dominique Devienne</td></tr><tr><td>Dong Wook</td></tr><tr><td>Drew DeVault</td></tr><tr><td>Eduard Català</td></tr><tr><td>Egor Chindyaskin</td></tr><tr><td>Egor Rogov</td></tr><tr><td>Ekaterina Kiryanova</td></tr><tr><td>Elena Indrupskaya</td></tr><tr><td>Elvis Pranskevichus</td></tr><tr><td>Emmanuel Quincerot</td></tr><tr><td>Emre Hasegeli</td></tr><tr><td>Eric Mutta</td></tr><tr><td>Erica Zhang</td></tr><tr><td>Erik Rijkers</td></tr><tr><td>Erki Eessaar</td></tr><tr><td>Etsuro Fujita</td></tr><tr><td>Euler Taveira</td></tr><tr><td>Fabien Coelho</td></tr><tr><td>Fabrice Chapuis</td></tr><tr><td>Fabrice Fontaine</td></tr><tr><td>Fabrízio de Royes Mello</td></tr><tr><td>Feike Steenbergen</td></tr><tr><td>Filip Gospodinov</td></tr><tr><td>Florin Irion</td></tr><tr><td>Floris Van Nee</td></tr><tr><td>Frédéric Yhuel</td></tr><tr><td>Gabriela Serventi</td></tr><tr><td>Gaurab Dey</td></tr><tr><td>Geoff Winkless</td></tr><tr><td>Geoffrey Blake</td></tr><tr><td>Georgios Kokolatos</td></tr><tr><td>Gilles Darold</td></tr><tr><td>Greg Nancarrow</td></tr><tr><td>Greg Rychlewski</td></tr><tr><td>Greg Sabino Mullane</td></tr><tr><td>Greg Stark</td></tr><tr><td>Gregory Smith</td></tr><tr><td>Guillaume Lelarge</td></tr><tr><td>Gunnar Bluth</td></tr><tr><td>Gurjeet Singh</td></tr><tr><td>Haiyang Wang</td></tr><tr><td>Haiying Tang</td></tr><tr><td>Hannu Krosing</td></tr><tr><td>Hans Buschmann</td></tr><tr><td>Hayato Kuroda</td></tr><tr><td>Heath Lord</td></tr><tr><td>Heikki Linnakangas</td></tr><tr><td>Herwig Goemans</td></tr><tr><td>Himanshu Upadhyaya</td></tr><tr><td>Holly Roberts</td></tr><tr><td>Hou Zhijie</td></tr><tr><td>Hubert Lubaczewski</td></tr><tr><td>Ian Barwick</td></tr><tr><td>Ian Campbell</td></tr><tr><td>Ibrar Ahmed</td></tr><tr><td>Ildus Kurbangaliev</td></tr><tr><td>Ilya Anfimov</td></tr><tr><td>Itamar Gafni</td></tr><tr><td>Jacob Champion</td></tr><tr><td>Jaime Casanova</td></tr><tr><td>Jakub Wartak</td></tr><tr><td>James Coleman</td></tr><tr><td>James Hilliard</td></tr><tr><td>James Inform</td></tr><tr><td>Jan Piotrowski</td></tr><tr><td>Japin Li</td></tr><tr><td>Jason Harvey</td></tr><tr><td>Jason Kim</td></tr><tr><td>Jean-Christophe Arnu</td></tr><tr><td>Jeevan Ladhe</td></tr><tr><td>Jeff Davis</td></tr><tr><td>Jeff Janes</td></tr><tr><td>Jehan-Guillaume de Rorthais</td></tr><tr><td>Jelte Fennema</td></tr><tr><td>Jeremy Evans</td></tr><tr><td>Jeremy Schneider</td></tr><tr><td>Jian Guo</td></tr><tr><td>Jian He</td></tr><tr><td>Jimmy Yih</td></tr><tr><td>Jiri Fejfar</td></tr><tr><td>Jitka Plesníková</td></tr><tr><td>Joe Conway</td></tr><tr><td>Joe Wildish</td></tr><tr><td>Joel Jacobson</td></tr><tr><td>Joey Bodoia</td></tr><tr><td>John Naylor</td></tr><tr><td>Jonathan Katz</td></tr><tr><td>Josef Simanek</td></tr><tr><td>Joseph Koshakow</td></tr><tr><td>Josh Soref</td></tr><tr><td>Joshua Brindle</td></tr><tr><td>Juan José Santamaría Flecha</td></tr><tr><td>Julien Rouhaud</td></tr><tr><td>Julien Roze</td></tr><tr><td>Junwang Zhao</td></tr><tr><td>Jürgen Purtz</td></tr><tr><td>Justin Pryzby</td></tr><tr><td>Ken Kato</td></tr><tr><td>Kevin Burke</td></tr><tr><td>Kevin Grittner</td></tr><tr><td>Kevin Humphreys</td></tr><tr><td>Kevin McKibbin</td></tr><tr><td>Kevin Sweet</td></tr><tr><td>Kevin Zheng</td></tr><tr><td>Klaudie Willis</td></tr><tr><td>Konstantin Knizhnik</td></tr><tr><td>Konstantina Skovola</td></tr><tr><td>Kosei Masumura</td></tr><tr><td>Kotaro Kawamoto</td></tr><tr><td>Koyu Tanigawa</td></tr><tr><td>Kuntal Ghosh</td></tr><tr><td>Kyotaro Horiguchi</td></tr><tr><td>Lars Kanis</td></tr><tr><td>Lauren Fliksteen</td></tr><tr><td>Laurent Hasson</td></tr><tr><td>Laurenz Albe</td></tr><tr><td>Leslie Lemaire</td></tr><tr><td>Liam Bowen</td></tr><tr><td>Lingjie Qiang</td></tr><tr><td>Liu Huailing</td></tr><tr><td>Louis Jachiet</td></tr><tr><td>Lukas Fittl</td></tr><tr><td>Ma Liangzhu</td></tr><tr><td>Maciek Sakrejda</td></tr><tr><td>Magnus Hagander</td></tr><tr><td>Mahendra Singh Thalor</td></tr><tr><td>Maksim Milyutin</td></tr><tr><td>Marc Bachmann</td></tr><tr><td>Marcin Krupowicz</td></tr><tr><td>Marcus Gartner</td></tr><tr><td>Marek Szuba</td></tr><tr><td>Marina Polyakova</td></tr><tr><td>Mario Emmenlauer</td></tr><tr><td>Mark Dilger</td></tr><tr><td>Mark Murawski</td></tr><tr><td>Mark Wong</td></tr><tr><td>Markus Wanner</td></tr><tr><td>Markus Winand</td></tr><tr><td>Martijn van Oosterhout</td></tr><tr><td>Martin Jurca</td></tr><tr><td>Martin Kalcher</td></tr><tr><td>Martín Marqués</td></tr><tr><td>Masahiko Sawada</td></tr><tr><td>Masahiro Ikeda</td></tr><tr><td>Masao Fujii</td></tr><tr><td>Masaya Kawamoto</td></tr><tr><td>Masayuki Hirose</td></tr><tr><td>Matthias van de Meent</td></tr><tr><td>Matthijs van der Vleuten</td></tr><tr><td>Maxim Orlov</td></tr><tr><td>Maxim Yablokov</td></tr><tr><td>Melanie Plageman</td></tr><tr><td>Michael Banck</td></tr><tr><td>Michael Harris</td></tr><tr><td>Michael J. Sullivan</td></tr><tr><td>Michael Meskes</td></tr><tr><td>Michael Mühlbeyer</td></tr><tr><td>Michael Paquier</td></tr><tr><td>Michael Powers</td></tr><tr><td>Mike Fiedler</td></tr><tr><td>Mike Oh</td></tr><tr><td>Mikhail Kulagin</td></tr><tr><td>Miles Delahunty</td></tr><tr><td>Naoki Okano</td></tr><tr><td>Nathan Bossart</td></tr><tr><td>Nathan Long</td></tr><tr><td>Nazir Bilal Yavuz</td></tr><tr><td>Neha Sharma</td></tr><tr><td>Neil Chen</td></tr><tr><td>Nicola Contu</td></tr><tr><td>Nicolas Lutic</td></tr><tr><td>Nikhil Benesch</td></tr><tr><td>Nikhil Shetty</td></tr><tr><td>Nikhil Sontakke</td></tr><tr><td>Nikita Glukhov</td></tr><tr><td>Nikolai Berkoff</td></tr><tr><td>Nikolay Samokhvalov</td></tr><tr><td>Nikolay Shaplov</td></tr><tr><td>Nitin Jadhav</td></tr><tr><td>Noah Misch</td></tr><tr><td>Noboru Saito</td></tr><tr><td>Noriyoshi Shinoda</td></tr><tr><td>Olaf Bohlen</td></tr><tr><td>Olly Betts</td></tr><tr><td>Onder Kalaci</td></tr><tr><td>Oskar Stenberg</td></tr><tr><td>Otto Kekalainen</td></tr><tr><td>Paul Guo</td></tr><tr><td>Paul Jungwirth</td></tr><tr><td>Paul Martinez</td></tr><tr><td>Pavan Deolasee</td></tr><tr><td>Pavel Borisov</td></tr><tr><td>Pavel Luzanov</td></tr><tr><td>Pavel Stehule</td></tr><tr><td>Peter Eisentraut</td></tr><tr><td>Peter Geoghegan</td></tr><tr><td>Peter Slavov</td></tr><tr><td>Peter Smith</td></tr><tr><td>Petr Jelínek</td></tr><tr><td>Phil Florent</td></tr><tr><td>Phil Krylov</td></tr><tr><td>Pierre-Aurélien Georges</td></tr><tr><td>Prabhat Sahu</td></tr><tr><td>Quan Zongliang</td></tr><tr><td>Rachel Heaton</td></tr><tr><td>Rahila Syed</td></tr><tr><td>Rajakavitha Kodhandapani</td></tr><tr><td>Rajkumar Raghuwanshi</td></tr><tr><td>Ranier Vilela</td></tr><tr><td>Rei Kamigishi</td></tr><tr><td>Reid Thompson</td></tr><tr><td>Rémi Lapeyre</td></tr><tr><td>Renan Soares Lopes</td></tr><tr><td>Richard Guo</td></tr><tr><td>Richard Wesley</td></tr><tr><td>RKN Sai Krishna</td></tr><tr><td>Robert Haas</td></tr><tr><td>Robert Treat</td></tr><tr><td>Roberto Mello</td></tr><tr><td>Robins Tharakan</td></tr><tr><td>Roger Mason</td></tr><tr><td>Roman Zharkov</td></tr><tr><td>Ronan Dunklau</td></tr><tr><td>Rui Zhao</td></tr><tr><td>Ryan Kelly</td></tr><tr><td>Ryo Matsumura</td></tr><tr><td>Ryohei Takahashi</td></tr><tr><td>Sadhuprasad Patro</td></tr><tr><td>Sait Talha Nisanci</td></tr><tr><td>Sami Imseih</td></tr><tr><td>Sandeep Thakkar</td></tr><tr><td>Sebastian Kemper</td></tr><tr><td>Sehrope Sarkuni</td></tr><tr><td>Sergei Kornilov</td></tr><tr><td>Sergei Shoulbakov</td></tr><tr><td>Sergey Shinderuk</td></tr><tr><td>Shay Rojansky</td></tr><tr><td>Shenhao Wang</td></tr><tr><td>Shi Yu</td></tr><tr><td>Shinya Kato</td></tr><tr><td>Shruthi Gowda</td></tr><tr><td>Simon Perepelitsa</td></tr><tr><td>Simon Riggs</td></tr><tr><td>Sirisha Chamarthi</td></tr><tr><td>Soumyadeep Chakraborty</td></tr><tr><td>Stan Hu</td></tr><tr><td>Stas Kelvich</td></tr><tr><td>Stefen Hillman</td></tr><tr><td>Stephen Frost</td></tr><tr><td>Steve Chavez</td></tr><tr><td>Sumanta Mukherjee</td></tr><tr><td>Suraj Khamkar</td></tr><tr><td>Suraj Kharage</td></tr><tr><td>Sven Klemm</td></tr><tr><td>Takamichi Osumi</td></tr><tr><td>Takayuki Tsunakawa</td></tr><tr><td>Takeshi Ideriha</td></tr><tr><td>Tatsuhiro Nakamori</td></tr><tr><td>Tatsuhito Kasahara</td></tr><tr><td>Tatsuo Ishii</td></tr><tr><td>Tatsuro Yamada</td></tr><tr><td>Teja Mupparti</td></tr><tr><td>Teodor Sigaev</td></tr><tr><td>Thibaud Walkowiak</td></tr><tr><td>Thom Brown</td></tr><tr><td>Thomas McKay</td></tr><tr><td>Thomas Munro</td></tr><tr><td>Tim McNamara</td></tr><tr><td>Timo Stolz</td></tr><tr><td>Timur Khanjanov</td></tr><tr><td>Tom Lane</td></tr><tr><td>Tomas Barton</td></tr><tr><td>Tomas Vondra</td></tr><tr><td>Tony Reix</td></tr><tr><td>Troy Frericks</td></tr><tr><td>Tushar Ahuja</td></tr><tr><td>Victor Wagner</td></tr><tr><td>Victor Yegorov</td></tr><tr><td>Vignesh C</td></tr><tr><td>Vik Fearing</td></tr><tr><td>Vincas Dargis</td></tr><tr><td>Vitaly Burovoy</td></tr><tr><td>Vitaly Voronov</td></tr><tr><td>Vladimir Sitnikov</td></tr><tr><td>Wang Ke</td></tr><tr><td>Wei Sun</td></tr><tr><td>Wei Wang</td></tr><tr><td>Whale Song</td></tr><tr><td>Will Mortensen</td></tr><tr><td>Wolfgang Walther</td></tr><tr><td>Yanliang Lei</td></tr><tr><td>Yaoguang Chen</td></tr><tr><td>Yogendra Suralkar</td></tr><tr><td>YoungHwan Joo</td></tr><tr><td>Yugo Nagata</td></tr><tr><td>Yukun Wang</td></tr><tr><td>Yura Sokolov</td></tr><tr><td>Yusuke Egashira</td></tr><tr><td>Yuzuko Hosoya</td></tr><tr><td>Zhang Mingli</td></tr><tr><td>Zhang Wenjie</td></tr><tr><td>Zhihong Yu</td></tr><tr><td>Zhiyong Wu</td></tr></table></div></div><div class="navfooter"><hr /><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="release-15-1.html" title="E.4. Release 15.1">Prev</a> </td><td width="20%" align="center"><a accesskey="u" href="release.html" title="Appendix E. Release Notes">Up</a></td><td width="40%" align="right"> <a accesskey="n" href="release-prior.html" title="E.6. Prior Releases">Next</a></td></tr><tr><td width="40%" align="left" valign="top">E.4. Release 15.1 </td><td width="20%" align="center"><a accesskey="h" href="index.html" title="PostgreSQL 15.4 Documentation">Home</a></td><td width="40%" align="right" valign="top"> E.6. Prior Releases</td></tr></table></div></body></html>