E.42. Выпуск 9.6.15
Дата выпуска: 2019-08-08
В этот выпуск вошли различные исправления, внесённые после версии 9.6.14. За информацией о нововведениях версии 9.6 обратитесь к Разделу E.57.
E.42.1. Миграция на версию 9.6.15
Если используется версия 9.6.X, выгрузка/восстановление базы не требуется.
Однако если вы обновляете сервер с более ранней версии, чем 9.6.9, см. Раздел E.48.
E.42.2. Изменения
Требование указания схемы при приведении к временному типу с использованием синтаксиса вызова функции (Ной Миш)
Мы давно требуем, чтобы вызов временных функций записывался с явным указанием временной схемы, примерно так:
pg_temp.
. Теперь её необходимо указывать и в приведении к временным типам с использованием функциональной записи:имя_функции
(аргументы
)pg_temp.
. В противном случае имеется возможность перехватить вызов функции, используя временный объект, что позволит повысить привилегии примерно тем же способом, который мы блокировали в CVE-2007-2138. (CVE-2019-10208)имя_типа
(аргумент
)Устранение сбоя в
ALTER TABLE ... ALTER COLUMN TYPE
при изменении типов нескольких столбцов в одной команде (Том Лейн)Тем самым устранена регрессия, которая появилась в предыдущих корректирующих выпусках: индексы, построенные по модифицируемым столбцам, обрабатывались неправильно, что приводило к странным ошибкам в процессе
ALTER TABLE
.Сохранение в
GROUP BY
значимости столбцов таблицы-родителя в иерархии наследования (Дэвид Роули)Обычно когда в предложении
GROUP BY
фигурируют столбцы первичного ключа таблицы, все остальные группирующие столбцы можно считать незначащими, так как первых вполне достаточно для получения уникальных групп. Но такая оптимизация некорректна, если запрос также обращается к дочерним таблицам — уникальность в родительской таблице не распространяется на дочерние.Устранение ненужных этапов сортировки в некоторых запросах с предложением
GROUPING SETS
(Эндрю Гирт, Ричард Гуо)Исправление поведения внешних ключей, содержащих несколько столбцов, при перестроении ограничения внешнего ключа (Том Лейн)
Команда
ALTER TABLE
могла неправильно определять, нужно ли перепроверять внешний ключ, если столбцы в ключе имели разные типы. По всей видимости проявлялось это всегда консервативным образом, то есть перепроверка производилась и тогда, когда это не требовалось.Устранение неоправданных взаимоблокировок при повышении уровня блокировки кортежа (Алексей Клюкин)
Когда две или более транзакций ждут, пока транзакция T1 освободит блокировку на уровне кортежа, а T1 при этом повышает уровень блокировки, по завершении T1 между этими ожидающими транзакциями может возникнуть неоправданная взаимоблокировка.
Устранение проблемы при разрешении взаимоблокировок, в которых задействовано несколько параллельных исполнителей (Жуй Хай Цзян)
Маловероятно, что эту ошибку можно было получить не синтетическими запросами, но в этом исключительном случае запросы, попавшие в ситуацию взаимоблокировки (в идеале разрешаемую автоматически), потребовалось бы отменить вручную.
Исправление преобразования диапазонов дат с бесконечными границами
infinity
с приведением их к канонической форме (Лауренц Альбе)Если граница диапазона — бесконечность, пытаться преобразовать открытый диапазон в закрытый и наоборот путём увеличения или уменьшения граничного значения нельзя. Поэтому в подобных случаях диапазон не должен изменяться.
Ликвидирована потеря дробных цифр при приведении очень больших значений типа
money
к типуnumeric
(Том Лейн)Исправление ассемблерного кода циклических блокировок для процессоров MIPS, чтобы он корректно работал на MIPS r6 (ЮньЦян Су)
Игнорирование символа перевода каретки (
\r
) при разборе файлов описаний служб в libpq (Том Лейн, Микаэль Пакье)В некоторых случаях такие файлы с переводами строк в стиле Windows могли разбираться неправильно, что проявлялось в ошибках при подключении.
Исключение некорректных вариантов дополнения табуляцией, предлагаемых после
SET
в psql (Том Лейн)переменная
=Исправление в pg_dump порядка вывода пользовательских классов операторов (Том Лейн)
Если пользовательский класс операторов оказывался классом операторов подтипа для пользовательского диапазонного типа, связанные объекты выводились в неправильном порядке; в результате выгруженные данные нельзя было восстановить. (Нижележащая ошибка в обработке зависимости классов операторов могла проявляться и в других случаях, но зафиксирован только этот.)
Обеспечение в
contrib/passwordcheck
возможности сосуществования с другими пользователями функцииcheck_password_hook
(Микаэль Пакье)Исправление проверок
contrib/sepgsql
для поддержки последних версий SELinux (Майк Пальмиотто)Улучшение стабильности регрессионных тестов
src/test/recovery
(Микаэль Пакье)Уменьшение объёма вывода в stderr в тестировочном скрипте pg_upgrade (Том Лейн)
Исправление TAP-тестов для совместимости с Perl из среды msys в случаях, когда каталог сборки находится не внутри точки монтирования корня msys (Ной Миш)
Обеспечение поддержки сборки Postgres с использованием Microsoft Visual Studio 2019 (Харибабу Комми)
При сборке проектов Visual Studio переменная окружения
WindowsSDKVersion
не должна игнорироваться, если она установлена (Пэйфэн Цю)Это исправление решает проблемы сборки в некоторых конфигурациях.
Поддержка в проектах Visual Studio библиотеки OpenSSL версии 1.1.0 и выше (Хуан Хосе Сантамария Флеча, Микаэль Пакье)
Возможность передачи параметров make нижележащей утилите gmake при вызове на верхнем уровне make не из комплекта GNU (Томас Манро)
Недопущение выбора вариантов
localtime
иposixrules
в качестве значенияTimeZone
в процессе initdb (Том Лейн)В некоторых случаях программа initdb могла выбирать одно из таких имён несуществующих часовых поясов вместо имени «настоящего» часового пояса. Этим двум именам будет предпочитаться любое другое, представляющее часовой пояс на уровне C.
Изменение представления
pg_timezone_names
: часовой поясFactory
будет отображаться, только если он имеет короткую аббревиатуру (Том Лейн)В прошлом администрация IANA ввела этот искусственный пояс с «аббревиатурой»
Local time zone must be set--see zic manual page
(Должен быть задан местный часовой пояс -- см. страницу руководства zic). Современные версии базы данных tzdb содержат для него аббревиатуру-00
, но на ряде платформ эта база модифицируется так, что из неё продолжают исходить подобные старинные написания. Поэтому решено показывать этот часовой пояс, только если его аббревиатура действительно кратка.Синхронизация нашей копии библиотеки timezone с выпущенной IANA версией 2019b (Том Лейн)
В результате была добавлена поддержка нового ключа
-b slim
программы zic, что позволяет уменьшить размер устанавливаемых файлов часовых поясов. Эта возможность может пригодиться нам в будущем.Обновление данных часовых поясов до версии tzdata 2019b, включающее изменение правил перехода на летнее время в Бразилии, а также корректировку исторических данных для Гонконга, Италии и Палестины.