Supported Versions: Current (16) / 15 / 14 / 13 / 12
Development Versions: devel
Unsupported versions: 11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0 / 7.4 / 7.3 / 7.2 / 7.1
This documentation is for an unsupported version of PostgreSQL.
You may want to view the same page for the current version, or one of the other supported versions listed above instead.

Appendix E. Release Notes

Table of Contents
E.1. Release 8.1.23
E.2. Release 8.1.22
E.3. Release 8.1.21
E.4. Release 8.1.20
E.5. Release 8.1.19
E.6. Release 8.1.18
E.7. Release 8.1.17
E.8. Release 8.1.16
E.9. Release 8.1.15
E.10. Release 8.1.14
E.11. Release 8.1.13
E.12. Release 8.1.12
E.13. Release 8.1.11
E.14. Release 8.1.10
E.15. Release 8.1.9
E.16. Release 8.1.8
E.17. Release 8.1.7
E.18. Release 8.1.6
E.19. Release 8.1.5
E.20. Release 8.1.4
E.21. Release 8.1.3
E.22. Release 8.1.2
E.23. Release 8.1.1
E.24. Release 8.1
E.25. Release 8.0.26
E.26. Release 8.0.25
E.27. Release 8.0.24
E.28. Release 8.0.23
E.29. Release 8.0.22
E.30. Release 8.0.21
E.31. Release 8.0.20
E.32. Release 8.0.19
E.33. Release 8.0.18
E.34. Release 8.0.17
E.35. Release 8.0.16
E.36. Release 8.0.15
E.37. Release 8.0.14
E.38. Release 8.0.13
E.39. Release 8.0.12
E.40. Release 8.0.11
E.41. Release 8.0.10
E.42. Release 8.0.9
E.43. Release 8.0.8
E.44. Release 8.0.7
E.45. Release 8.0.6
E.46. Release 8.0.5
E.47. Release 8.0.4
E.48. Release 8.0.3
E.49. Release 8.0.2
E.50. Release 8.0.1
E.51. Release 8.0
E.52. Release 7.4.30
E.53. Release 7.4.29
E.54. Release 7.4.28
E.55. Release 7.4.27
E.56. Release 7.4.26
E.57. Release 7.4.25
E.58. Release 7.4.24
E.59. Release 7.4.23
E.60. Release 7.4.22
E.61. Release 7.4.21
E.62. Release 7.4.20
E.63. Release 7.4.19
E.64. Release 7.4.18
E.65. Release 7.4.17
E.66. Release 7.4.16
E.67. Release 7.4.15
E.68. Release 7.4.14
E.69. Release 7.4.13
E.70. Release 7.4.12
E.71. Release 7.4.11
E.72. Release 7.4.10
E.73. Release 7.4.9
E.74. Release 7.4.8
E.75. Release 7.4.7
E.76. Release 7.4.6
E.77. Release 7.4.5
E.78. Release 7.4.4
E.79. Release 7.4.3
E.80. Release 7.4.2
E.81. Release 7.4.1
E.82. Release 7.4
E.83. Release 7.3.21
E.84. Release 7.3.20
E.85. Release 7.3.19
E.86. Release 7.3.18
E.87. Release 7.3.17
E.88. Release 7.3.16
E.89. Release 7.3.15
E.90. Release 7.3.14
E.91. Release 7.3.13
E.92. Release 7.3.12
E.93. Release 7.3.11
E.94. Release 7.3.10
E.95. Release 7.3.9
E.96. Release 7.3.8
E.97. Release 7.3.7
E.98. Release 7.3.6
E.99. Release 7.3.5
E.100. Release 7.3.4
E.101. Release 7.3.3
E.102. Release 7.3.2
E.103. Release 7.3.1
E.104. Release 7.3
E.105. Release 7.2.8
E.106. Release 7.2.7
E.107. Release 7.2.6
E.108. Release 7.2.5
E.109. Release 7.2.4
E.110. Release 7.2.3
E.111. Release 7.2.2
E.112. Release 7.2.1
E.113. Release 7.2
E.114. Release 7.1.3
E.115. Release 7.1.2
E.116. Release 7.1.1
E.117. Release 7.1
E.118. Release 7.0.3
E.119. Release 7.0.2
E.120. Release 7.0.1
E.121. Release 7.0
E.122. Release 6.5.3
E.123. Release 6.5.2
E.124. Release 6.5.1
E.125. Release 6.5
E.126. Release 6.4.2
E.127. Release 6.4.1
E.128. Release 6.4
E.129. Release 6.3.2
E.130. Release 6.3.1
E.131. Release 6.3
E.132. Release 6.2.1
E.133. Release 6.2
E.134. Release 6.1.1
E.135. Release 6.1
E.136. Release 6.0
E.137. Release 1.09
E.138. Release 1.02
E.139. Release 1.01
E.140. Release 1.0
E.141. Postgres95 Release 0.03
E.142. Postgres95 Release 0.02
E.143. Postgres95 Release 0.01

The release notes contain the significant changes in each PostgreSQL release, with major features and migration issues listed at the top. The release notes do not contain changes that affect only a few users or changes that are internal and therefore not user-visible. For example, the optimizer is improved in almost every release, but the improvements are usually observed by users as simply faster queries.

A complete list of changes for each release can be obtained by viewing the Git logs for each release. The pgsql-committers email list records all source code changes as well. There is also a web interface that shows changes to specific files.

The name appearing next to each item represents the major developer for that item. Of course all changes involve community discussion and patch review, so each item is truly a community effort.

E.1. Release 8.1.23

Release date: 2010-12-16

This release contains a variety of fixes from 8.1.22. For information about new features in the 8.1 major release, see Section E.24.

This is expected to be the last PostgreSQL release in the 8.1.X series. Users are encouraged to update to a newer release branch soon.

E.1.1. Migration to Version 8.1.23

A dump/restore is not required for those running 8.1.X. However, if you are upgrading from a version earlier than 8.1.18, see the release notes for 8.1.18.

E.1.2. Changes

  • Force the default wal_sync_method to be fdatasync on Linux (Tom Lane, Marti Raudsepp)

    The default on Linux has actually been fdatasync for many years, but recent kernel changes caused PostgreSQL to choose open_datasync instead. This choice did not result in any performance improvement, and caused outright failures on certain filesystems, notably ext4 with the data=journal mount option.

  • Fix recovery from base backup when the starting checkpoint WAL record is not in the same WAL segment as its redo point (Jeff Davis)

  • Add support for detecting register-stack overrun on IA64 (Tom Lane)

    The IA64 architecture has two hardware stacks. Full prevention of stack-overrun failures requires checking both.

  • Add a check for stack overflow in copyObject() (Tom Lane)

    Certain code paths could crash due to stack overflow given a sufficiently complex query.

  • Fix detection of page splits in temporary GiST indexes (Heikki Linnakangas)

    It is possible to have a "concurrent" page split in a temporary index, if for example there is an open cursor scanning the index when an insertion is done. GiST failed to detect this case and hence could deliver wrong results when execution of the cursor continued.

  • Avoid memory leakage while ANALYZE'ing complex index expressions (Tom Lane)

  • Ensure an index that uses a whole-row Var still depends on its table (Tom Lane)

    An index declared like create index i on t (foo(t.*)) would not automatically get dropped when its table was dropped.

  • Do not "inline" a SQL function with multiple OUT parameters (Tom Lane)

    This avoids a possible crash due to loss of information about the expected result rowtype.

  • Fix constant-folding of COALESCE() expressions (Tom Lane)

    The planner would sometimes attempt to evaluate sub-expressions that in fact could never be reached, possibly leading to unexpected errors.

  • Add print functionality for InhRelation nodes (Tom Lane)

    This avoids a failure when debug_print_parse is enabled and certain types of query are executed.

  • Fix incorrect calculation of distance from a point to a horizontal line segment (Tom Lane)

    This bug affected several different geometric distance-measurement operators.

  • Fix PL/pgSQL's handling of "simple" expressions to not fail in recursion or error-recovery cases (Tom Lane)

  • Fix bug in contrib/cube's GiST picksplit algorithm (Alexander Korotkov)

    This could result in considerable inefficiency, though not actually incorrect answers, in a GiST index on a cube column. If you have such an index, consider REINDEXing it after installing this update.

  • Don't emit "identifier will be truncated" notices in contrib/dblink except when creating new connections (Itagaki Takahiro)

  • Fix potential coredump on missing public key in contrib/pgcrypto (Marti Raudsepp)

  • Fix memory leak in contrib/xml2's XPath query functions (Tom Lane)

  • Update time zone data files to tzdata release 2010o for DST law changes in Fiji and Samoa; also historical corrections for Hong Kong.