©
This document usesPHP Chinese website manualRelease
Release date:2009-03-16
This release contains a variety of fixes from 8.1.16. For information about new features in the 8.1 major release, see Section E.76.
A dump/restore is not required for those running 8.1.X. However, if you are upgrading from a version earlier than 8.1.15, see the release notes for 8.1.15.
Prevent error recursion crashes when encoding conversion fails (Tom)
This change extends fixes made in the last two minor releases for related failure scenarios. The previous fixes were narrowly tailored for the original problem reports, but we have now recognized thatanyerror thrown by an encoding conversion function could potentially lead to infinite recursion while trying to report the error. The solution therefore is to disable translation and encoding conversion and report the plain-ASCII form of any error message, if we find we have gotten into a recursive error reporting situation. (CVE-2009-0922)
DisallowCREATE CONVERSIONwith the wrong encodings for the specified conversion function (Heikki)
This prevents one possible scenario for encoding conversion failure. The previous change is a backstop to guard against other kinds of failures in the same area.
Fix core dump whento_char()
is given format codes that are inappropriate for the type of the data argument (Tom)
Fix decompilation ofCASE WHENwith an implicit coercion (Tom)
This mistake could lead to Assert failures in an Assert-enabled build, or an"unexpected CASE WHEN clause"error message in other cases, when trying to examine or dump a view.
Fix possible misassignment of the owner of a TOAST table's rowtype (Tom)
IfCLUSTERor a rewriting variant ofALTER TABLEwere executed by someone other than the table owner, thepg_typeentry for the table's TOAST table would end up marked as owned by that someone. This caused no immediate problems, since the permissions on the TOAST rowtype aren't examined by any ordinary database operation. However, it could lead to unexpected failures if one later tried to drop the role that issued the command (in 8.1 or 8.2), or"owner of data type appears to be invalid"warnings frompg_dumpafter having done so (in 8.3).
Clean up PL/pgSQL error status variables fully at block exit (Ashesh Vashi and Dave Page)
This is not a problem for PL/pgSQL itself, but the omission could cause the PL/pgSQL Debugger to crash while examining the state of a function.
AddMUST(Mauritius Island Summer Time) to the default list of known timezone abbreviations (Xavier Bugaud)