E.8. Выпуск 13

Дата выпуска: 2020-09-24

E.8.1. Обзор

PostgreSQL 13 содержит много новых возможностей и улучшений, в том числе:

  • Экономия дискового пространства и увеличение быстродействия за счёт исключения дубликатов в индексах-B-деревьях

  • Увеличение производительности запросов в части использования секционированных таблиц и агрегатных функций

  • Улучшение планов запросов с использованием расширенной статистики

  • Распараллеливание очистки индексов

  • Инкрементальная сортировка

Предыдущие пункты и другие новые возможности PostgreSQL 13 более подробно описаны в следующих разделах.

E.8.2. Миграция на версию 13

Тем, кто хочет перенести данные из любой предыдущей версии, необходимо выполнить выгрузку/загрузку данных с помощью pg_dumpall либо использовать pg_upgrade или логическую репликацию. Общую информацию о переходе на более новую основную версию можно найти в Разделе 17.6.

В версии 13 реализован ряд изменений, которые могут повлиять на совместимость с предыдущими выпусками. Рассмотрите следующие несовместимые аспекты:

  • Команда SIMILAR TO ... ESCAPE NULL теперь возвращает NULL (Том Лейн)

    Новое поведение соответствует стандарту SQL. Ранее ESCAPE NULL воспринималось как указание использовать спецсимвол по умолчанию (обратную косую черту). Это также касается функции substring(текст FROM шаблон ESCAPE текст). Предыдущее поведение будет сохранено в ранее созданных представлениях, для этого оставлена исходная функция.

  • Дополнение проверки слова string в функциях json[b]_to_tsvector() (Доминик Чарнота)

  • Изменение зависимости степени параллельности от значений effective_io_concurrency (Томас Манро)

    Ранее значение этого параметра пересчитывалось и влияло на число параллельных операций косвенно, теперь же оно используется непосредственно. При этом влияние значения по умолчанию не изменилось. Преобразовать старые значения в новые можно по формуле:

    SELECT round(sum(СТАРОЕ_ЗНАЧЕНИЕ / n::float)) AS newvalue FROM generate_series(1, СТАРОЕ_ЗНАЧЕНИЕ) s(n);
  • Исключение вспомогательных процессов из системных представлений pg_stat_ssl и pg_stat_gssapi (Эйлер Тавейра)

    В запросах, которые соединяют эти представления с pg_stat_activity, ожидая получить информацию и о таких процессах, теперь нужно будет использовать левые соединения.

  • Переименование различных событий ожидания для единообразия (Фудзии Масао, Том Лейн)

  • Смена тега, выдаваемого командой ALTER FOREIGN TABLE ... RENAME COLUMN, на более подходящий (Фудзии Масао)

    Теперь она будет выдавать тег ALTER FOREIGN TABLE вместо ALTER TABLE.

  • Смена тега, выдаваемого командой ALTER MATERIALIZED VIEW ... RENAME COLUMN, на более подходящий (Фудзии Масао)

    Теперь она будет выдавать тег ALTER MATERIALIZED VIEW вместо ALTER TABLE.

  • Переименование параметра конфигурации wal_keep_segments в wal_keep_size (Фудзии Масао)

    Этот параметр определяет объём WAL, который нужно сохранять для ведомых серверов, в мегабайтах, а не в количестве файлов, как старый параметр. Если ранее вы использовали wal_keep_segments, соответствующее значение нового параметра можно вычислить так:

    wal_keep_size = wal_keep_segments * wal_segment_size (обычно 16 Мбайт)
  • Прекращение поддержки определения классов операторов с использованием синтаксиса, который был принят в PostgreSQL до версии 8.0 (Даниэль Густафссон)

  • Прекращение поддержки определения ограничений внешнего ключа с использованием синтаксиса, который был принят в PostgreSQL до версии 7.3 (Даниэль Густафссон)

  • Прекращение поддержки псевдотипов «opaque», необходимых для серверов PostgreSQL до версии 7.3 (Даниэль Густафссон)

  • Прекращение поддержки обновления неупакованных (созданных до версии 9.1) расширений (Том Лейн)

    Указание FROM команды CREATE EXTENSION более не поддерживается. Там, где по-прежнему используются неупакованные расширения, их нужно заменить упакованными, прежде чем производить обновление PostgreSQL до версии 13.

  • Ликвидация поддержки файлов posixrules в базе часовых поясов (Том Лейн)

    Координаторы базы часовых поясов IANA признали эту функциональность устаревшей; таким образом, она будет постепенно уходить из баз данных в составе операционных систем на протяжении нескольких лет. Мы решили отказаться от поддержки этой функциональности в 13 версии PostgreSQL, не дожидаясь, когда она будет вдруг ликвидирована в одном из обновлений базы часовых поясов. Это изменение касается только указаний часовых поясов в стиле POSIX, в которых нельзя явно задать правило перехода на летнее время; ранее нужное правило можно было определить, установив собственный файл posixrules, но теперь оно зашито в коде. В инсталляциях, которые зависят от старой функциональности, рекомендуется перейти к использованию географического названия часового пояса.

  • Исправление в ltree интерпретации смежных звёздочек с фигурными скобками в путях lquery; например, путь *{2}.*{3} должен восприниматься как *{5} (Никита Глухов)

  • Смена типов, выдаваемых функцией bt_metap() модуля pageinspect, на более подходящие в целях исключения переполнений (Питер Гейган)

E.8.3. Изменения

Ниже вы найдёте подробный список изменений, произошедших между предыдущим основным выпуском и выпуском PostgreSQL 13.

E.8.3.1. Сервер

  • Увеличение числа случаев, когда может иметь место устранение секций (Юзуко Хосоя, Амит Ланготе, Альваро Эррера)

  • Поддержка соединения с учётом секционирования в большем числе случаев (Ашутош Бапат, Эцуро Фудзита, Амит Ланготе, Том Лейн)

    Например, теперь такие соединения возможны даже между секционированными таблицами, границы секций в которых не совпадают в точности.

  • Добавление поддержки триггеров BEFORE уровня строк в секционированных таблицах (Альваро Эррера)

    Заметьте, что в таких триггерах нельзя изменить целевую секцию строки.

  • Реализация возможности логической репликации секционированных таблиц через публикации (Амит Ланготе)

    Ранее секции надо было реплицировать индивидуально, но теперь можно явно опубликовать секционированную таблицу, и при этом автоматически будут опубликованы все её секции. При добавлении/удалении секций из секционированных таблиц они так же автоматически будут добавляться/удаляться из публикаций. Будут ли изменения в секциях публиковаться на уровне секций или на уровне родителя, определяет параметр publish_via_partition_root команды CREATE PUBLICATION.

  • Поддержка логической репликации в секционированные таблицы на стороне подписчика (Амит Ланготе)

    Ранее подписчики могли получать строки только в несекционированные таблицы.

  • Поддержка использования переменных вида таблица.* (включающих всю строку) в секционирующих выражениях (Амит Ланготе)

E.8.3.1.2. Индексы
  • Более эффективное хранение дубликатов в индексах-B-деревьях (Анастасия Лубенникова, Питер Гейган)

    Хранение повторяющихся ключей в единственном экземпляре позволяет оптимизировать индексы-B-деревья, построенные по столбцам, имеющим малую мощность. Пользователи, мигрирующие на новую версию посредством pg_upgrade, должны выполнить REINDEX для существующих индексов, чтобы задействовать для них эту оптимизацию.

  • Возможность использования индексов GiST и SP-GiST по столбцам box для поддержки запросов ORDER BY прямоугольник <-> точка (Никита Глухов)

  • Более эффективная обработка операторов ! (НЕ) в запросах tsquery с использованием индексов GIN (Никита Глухов, Александр Коротков, Том Лейн, Жюльен Руо)

  • Возможность определения параметров для классов операторов в индексах (Никита Глухов)

  • Возможность указания в CREATE INDEX размера сигнатуры и максимального количества целочисленных диапазонов для GiST (Никита Глухов)

    В индексах по столбцам tsvector, pg_trgm, ltree, hstore и массивам с четырёх- и восьмибайтовыми целыми теперь можно сменить подразумеваемые значения этих параметров GiST на более подходящие.

  • Недопущение добавления индексов, использующих нестандартные правила сортировки, в ограничения уникальности или первичного ключа (Том Лейн)

    Для индекса и для нижележащего столбца должно быть задано одно правило сортировки, однако раньше команда ALTER TABLE это не контролировала.

E.8.3.1.3. Оптимизатор
  • Улучшение в оптимизаторе оценки избирательности для операторов включения/совпадения (Том Лейн)

  • Возможность определения ориентиров статистики для объектов расширенной статистики (Томаш Вондра)

    Для этого предназначен новый вариант команды ALTER STATISTICS ... SET STATISTICS. Ранее эти значения выбирались исходя из более общих ориентиров статистики.

  • Возможность использования нескольких объектов расширенной статистики в одном запросе (Томаш Вондра)

  • Возможность использования объектов расширенной статистики для предложений OR и условий IN/ANY со списком констант (Пьер Дюкроке, Томаш Вондра)

  • Возможность встраивания (подтягивания в место использования) функций, фигурирующих в предложении FROM, если они сводятся к константе (Александр Кузьменков, Александр Парфёнов)

E.8.3.1.4. Общая производительность
  • Реализация инкрементальной сортировки (Джеймс Коулман, Александр Коротков, Томаш Вондра)

    Если известно, что промежуточный результат запроса упорядочен по одному или нескольким начальным ключам запрошенного порядка сортировки, дополнительную сортировку можно выполнить, рассмотрев только оставшиеся ключи. Для этого строки должны быть собраны в группы с одинаковыми значениями начальных ключей.

    Изменить это поведение при необходимости позволяет параметр enable_incremental_sort.

  • Ускорение сортировки значений inet (Брандур Лич)

  • Возможность использования дискового хранилища для агрегирования по хешу при обработке большого объёма результатов (Джефф Девис)

    Ранее агрегирование по хешу выбиралось, только если расчётное количество необходимой для него памяти не превышало work_mem. Теперь же такого ограничения нет. Если объём хеш-таблицы превысит значение work_mem, умноженное на hash_mem_multiplier, она будет вытеснена на диск.

    Это поведение в большинстве случаев должно быть лучше старого, когда после выбора варианта агрегирования по хешу хеш-таблица должна была находиться в памяти, какой бы большой она ни была (при ошибке планировщика она могла оказаться очень объёмной). Но при необходимости подобное прежнему поведение можно получить, увеличив hash_mem_multiplier.

  • Возможность запуска автоочистки в процессе autovacuum в зависимости от числа добавленных строк, а не только от числа удалённых или изменённых (Лауренц Альбе, Дорофей Пролесковский)

    Ранее, если строки только добавлялись в таблицу, могла вызываться процедура автоанализа, но не процедура автоочистки, из тех соображений, что при этом не появляются «мёртвые» кортежи, которые нужно удалять. Однако сканирование в процессе очистки полезно и тем, что в ходе его выполнения устанавливаются биты полностью видимых страниц, позволяющие увеличить эффективность сканирования только по индексу. Кроме того, когда таблицу, в которую только добавляются записи, периодически обрабатывает процедура очистки, это способствует распределению работы по «замораживанию» старых кортежей, что позволяет избежать необходимости экстренно обрабатывать сразу всю таблицу для предотвращения зацикливания транзакций.

    При необходимости это поведение можно скорректировать, воспользовавшись новыми параметрами autovacuum_vacuum_insert_threshold и autovacuum_vacuum_insert_scale_factor или аналогичными параметрами хранения таблицы.

  • Добавление параметра maintenance_io_concurrency для управления степенью параллельности ввода/вывода при выполнении операций обслуживания (Томас Манро)

  • Возможность обойтись без записи в WAL во время транзакции, которая создаёт или полностью переписывает отношение, при wal_level равном minimal (Кётаро Хоригути)

    Отношения, объём которых превышает wal_skip_threshold, теперь могут сразу сбрасываться в файловую систему в обход WAL. Ранее это делалось только при выполнении COPY, но в прежней реализации обнаружился дефект, чреватый потерей данных при восстановлении после сбоя.

  • Ускорение воспроизведения команд DROP DATABASE в случае использования множества табличных пространств (Фудзии Масао)

  • Ускорение операции опустошения очень больших отношений (Кирк Джемисон)

  • Оптимизация излечения начальных байтов из значений TOAST (Бинго Бао, Андрей Бородин)

    Ранее сжатые отдельно значения TOAST считывались полностью, даже когда было известно, что потребуются только несколько начальных байт. Теперь считываться будут только те данные, которые нужны для получения результата.

  • Оптимизация производительности команд LISTEN/NOTIFY (Мартейн Ван Остерхаут, Том Лейн)

  • Ускорение перевода целых чисел в текстовый вид (Давид Феттер)

  • Уменьшение объёма памяти, который занимают обрабатываемые строки запросов и скрипты расширений, содержащие множество SQL-операторов (Амит Ланготе)

E.8.3.1.5. Мониторинг
  • Возможность отслеживания статистики использования WAL, в том числе при автоочистке, в EXPLAIN, auto_explain и в pg_stat_statements (Кирилл Бычик, Жюльен Руо)

  • Возможность протоколирования не всех, а только выборочного множества SQL-операторов (Адриен Найрат)

    В журнал будет вноситься задаваемая параметром log_statement_sample_rate доля от всех операторов, длительность которых превышает log_min_duration_sample.

  • Добавление типа обслуживающего процесса в формат csvlog и возможность добавления этого типа в log_line_prefix (Питер Эйзентраут)

  • Гибкое управление выводом параметров подготовленных операторов, вносимых в журнал (Алексей Баштанов, Альваро Эррера)

    Новый параметр GUC log_parameter_max_length_on_error задаёт максимальную длину для значений параметров оператора, который вносится в журнал по причине ошибки, а log_parameter_max_length ограничивает длину параметров для оператора, вносимого по другим причинам. Ранее в случае ошибок параметры подготовленных операторов никогда не выводились в журнал.

  • Возможность добавления в журнал стека вызовов после возникновения ошибки (Питер Эйзентраут, Альваро Эррера)

    Для каких функций в коде C должен записываться стек в случае ошибки в них, определяется новым параметром backtrace_functions.

  • Перевод счётчиков использования буферов при очистке на 64-битные целые во избежание переполнения (Альваро Эррера)

E.8.3.1.6. Системные представления
  • Добавление в представление pg_stat_activity поля leader_pid, позволяющего определить ведущий процесс для параллельных исполнителей (Жюльен Руо)

  • Добавление системного представления pg_stat_progress_basebackup для наблюдения за передачей потока данных в ходе базового копирования (Фудзии Масао)

  • Добавление системного представления pg_stat_progress_analyze для наблюдения за выполнением команды ANALYZE (Альваро Эррера, Тацуро Ямада, Винаяк Покале)

  • Добавление системного представления pg_shmem_allocations для отслеживания использования общей памяти (Андрес Фройнд, Роберт Хаас)

  • Добавление системного представления pg_stat_slru для наблюдения за внутренними SLRU-кешами (Томаш Вондра)

  • Увеличение максимально допустимого значения track_activity_query_size до 1 Мбайта (Вячеслав Макаров)

    Ранее верхний предел равнялся 100 килобайтам.

  • Добавление события ожидания, связанного с выделением DSM-сегмента функцией posix_fallocate() (Томас Манро)

  • Добавление события ожидания VacuumDelay, представляющего задержку очистки по стоимости (Джастин Призби)

  • Добавление событий ожидания, представляющих паузы в процессе архивирования и восстановления WAL (Фудзии Масао)

    Новые события называются BackupWaitWalArchive и RecoveryPause.

  • Добавление событий ожидания RecoveryConflictSnapshot и RecoveryConflictTablespace для наблюдения за конфликтами восстановления (Масахико Савада)

  • Оптимизация производительности при обработке событий ожидания в системах на базе BSD (Томас Манро)

E.8.3.1.8. Аутентификация
  • Недопущение чтения параметра ssl_passphrase_command обычными пользователями (Инсон Мун)

    Доступ к нему был ограничен из соображений безопасности.

  • Смена выбираемой сервером по умолчанию минимальной версии протокола защиты соединений TLS с 1.0 на 1.2 (Питер Эйзентраут)

    Выбрать другую версию позволяет параметр ssl_min_protocol_version.

E.8.3.1.9. Конфигурация сервера
  • Усиление ограничений, при которых допускается выполнение служебных команд в транзакции без записи (Роберт Хаас)

    Вместе с тем увеличено количество служебных команд, которые могут выполняться в параллельных запросах.

  • Добавление возможности изменения параметра allow_system_table_mods после запуска сервера (Питер Эйзентраут)

  • Предотвращение изменения системных таблиц обычными пользователями при установленном параметре allow_system_table_mods (Питер Эйзентраут)

    Ранее, если при запуске сервера был установлен параметр allow_system_table_mods, обычные пользователи могли выполнять операции INSERT/UPDATE/DELETE с системными таблицами.

  • Реализация поддержки Unix-сокетов в Windows (Питер Эйзентраут)

E.8.3.2. Потоковая репликация и восстановление

  • Применение изменённых параметров потоковой репликации при перезагрузке конфигурации (Сергей Корнилов)

    Ранее для изменения действующих значений primary_conninfo и primary_slot_name требовалось перезапустить сервер.

  • Возможность использования WAL-приёмниками временного слота репликации в ситуациях, когда постоянный слот не определён (Питер Эйзентраут, Сергей Корнилов)

    Новое поведение включается параметром wal_receiver_create_temp_slot.

  • Ограничение объёма хранилища WAL, требуемого для слотов репликации, параметром max_slot_wal_keep_size (Кётаро Хоригути)

    Слоты репликации, которым заданного объёма недостаточно, помечаются как нерабочие.

  • Отмена паузы при поступлении признанного более приоритетным запроса на повышение ведомого (Фудзии Масао)

    До этого нельзя было перейти к повышению непосредственно из состояния паузы.

  • Завершение восстановления ошибкой в случаях, когда заданная цель восстановления не достигается (Лейф Гуннар Эрландсен, Питер Эйзентраут)

    Ранее сервер успешно повышался, доходя до конца WAL, даже если заданная цель не была достигнута.

  • Ограничение объёма памяти, выделяемой для логического декодирования, после превышении которого данные вытесняются на диск (Томаш Вондра, Дилип Кумар, Амит Капила)

    Этот объём задаётся параметром logical_decoding_work_mem.

  • Возможность продолжения восстановления даже при обнаружении в WAL ссылок на неверные страницы (Фудзии Масао)

    Для включения этой возможности предназначен параметр ignore_invalid_pages.

E.8.3.3. Служебные команды

  • Возможность параллельной обработки индексов одной таблицы в ходе VACUUM (Масахико Савада, Амит Капила)

    Этой возможностью управляет новый параметр PARALLEL.

  • Дополнение предложения FETCH FIRST указанием WITH TIES, позволяющим получить все дополнительные строки, совпадающие с последней строкой результата (Сурафел Темесген)

  • Добавление в вывод EXPLAIN с указанием BUFFER сведений об использования буферов во время планирования (Жюльен Руо)

  • Обеспечение переноса командой CREATE TABLE LIKE свойства NO INHERIT, которое может быть у ограничений, в создаваемую таблицу (Ильдар Мусин, Крис Трэверс)

  • Избавление от проверок разрешений в подчинённых таблицах при выполнении LOCK TABLE для секционированной таблицы (Амит Ланготе)

  • Поддержка указания OVERRIDING USER VALUE при добавлении данных в столбцы идентификации (Дин Рашид)

  • Добавление конструкции ALTER TABLE ... DROP EXPRESSION, позволяющей убрать у столбца свойство GENERATED (Питер Эйзентраут)

  • Исправление ошибок в поведении многоэтапных команд ALTER TABLE (Том Лейн)

    Предложения IF NOT EXISTS теперь работают ожидаемым образом, то есть вторичные действия (например, создание индекса) не выполняются, если столбец уже существует. Кроме того, теперь корректно выполняются некоторые сочетания действий ALTER TABLE, которые раньше не работали.

  • Добавление в синтаксис ALTER VIEW возможности переименования столбцов представления (Фудзии Масао)

    Переименовать столбцы представления можно было и раньше, но только с помощью команды ALTER TABLE RENAME COLUMN, что вносило путаницу.

  • Добавление в ALTER TYPE возможности изменять характеристики TOAST и опорные функции для базовых типов (Томаш Вондра, Том Лейн)

  • Добавление в CREATE DATABASE параметра LOCALE (Питер Эйзентраут)

    В новом параметре объединены два ранее существовавших параметра LC_COLLATE и LC_CTYPE.

  • Реализация в DROP DATABASE возможности принудительно удалить базу, отключив от неё пользователей (Павел Стехуле, Амит Капила)

    Для такого удаления предназначено указание FORCE.

  • Добавление во внутреннюю структуру поля tg_updatedcols, из которого триггеры на C, обрабатывающие изменения, могут узнать, какие столбцы были изменены (Питер Эйзентраут)

E.8.3.4. Типы данных

  • Добавление новых полиморфных типов данных, полезных для функций, принимающих совместимые аргументы (Павел Стехуле)

    А именно, добавлены типы anycompatible, anycompatiblearray, anycompatiblenonarray и anycompatiblerange.

  • Добавление SQL-типа xid8 для представления полных идентификаторов транзакций (Томас Манро)

    Существовавший и ранее тип xid имеет размер всего 4 байта и не вмещает эпоху транзакции.

  • Добавление типа данных regcollation и вспомогательных функций, представляющих в понятном виде OID правил сортировки (Жюльен Руо)

  • Использование версии gcc в качестве идентификатора версии правила сортировки там, где это уместно (Томас Манро)

    Теперь при смене версии glibc будет выдаваться предупреждение о возможном повреждении индексов, зависящих от правил сортировки.

  • Поддержка версионирования правил сортировки в Windows (Томас Манро)

  • Возможность извлечения членов выражений ROW с использованием суффиксной записи (Том Лейн)

    Например, результатом выражения (ROW(4, 5.0)).f1 будет 4.

E.8.3.5. Функции

  • Добавление альтернативного варианта jsonb_set() с расширенной обработкой NULL (Эндрю Дунстан)

    Новая функция jsonb_set_lax(), получая NULL в качестве нового значения, может по выбору вызывающего присвоить JSON-значение null заданному ключу, удалить ключ, выдать исключение или возвратить неизменённое значение jsonb.

  • Добавление в jsonpath метода .datetime() (Никита Глухов, Фёдор Сигаев, Олег Бартунов, Александр Коротков)

    Этот метод позволяет преобразовывать значения JSON в значения времени, которыми затем можно оперировать в выражениях jsonpath. При этом также добавлены функции jsonpath, выдающие результат с учётом часового пояса.

  • Добавление SQL-функции NORMALIZE() для нормализации строк в Unicode и конструкции IS NORMALIZED для проверки нормализации (Питер Эйзентраут)

  • Добавление агрегатных функций min() и max() для типа pg_lsn (Фабрицио де Ройес Мелло)

    Они могут быть полезны прежде всего в запросах, выполняемых в целях мониторинга.

  • Возможность указания в виде спецпоследовательности Unicode (например, E'\unnnn' или U&'\nnnn') любого символа, допустимого в кодировке базы данных, даже если это не UTF-8 (Том Лейн)

  • Добавление в to_date() и to_timestamp() возможности распознавать не только английские названия дней недели/месяцев (Хуан Хосе Сантамария Флеча, Том Лейн)

    Допустимыми будут те же названия, что выводит функция to_char() с теми же шаблонами формата.

  • Добавление шаблонов формата даты/времени FF1FF6 для ввода или вывода от 1 до 6 цифр в дробной части секунд (Александр Коротков, Никита Глухов, Фёдор Сигаев, Олег Бартунов)

    Такие шаблоны могут приниматься функциями to_char(), to_timestamp(), а также методом jsonpath .datetime().

  • Добавление шаблона формата даты/времени SSSSS в качестве соответствующего стандарту SQL синонима для SSSS (Никита Глухов, Александр Коротков)

  • Реализация функции gen_random_uuid(), генерирующей UUID версии 4 (Питер Эйзентраут)

    Ранее сгенерировать UUID можно было только дополнительными функциями, реализованными во внешних модулях uuid-ossp и pgcrypto.

  • Добавление функций gcd и lcm, вычисляющих наибольший общий делитель и наименьшее общее кратное, соответственно (Вик Фиринг)

  • Увеличение быстродействия и точности вычисления квадратного корня (sqrt) и натурального логарифма (ln) для значений numeric (Дин Рашид)

  • Реализация функции min_scale(), которая выдаёт количество цифр справа от десятичной точки, необходимое для представления значения numeric с полной точностью (Павел Стехуле)

  • Реализация функции trim_scale(), которая уменьшает масштаб значения numeric, убирая конечные нули (Павел Стехуле)

  • Добавление коммутативных операторов к операторам, вычисляющим расстояние (Никита Глухов)

    Например, до этого поддерживалась только операция point <-> line, а теперь поддерживается и line <-> point.

  • Создание для всех функций, работающих с идентификаторами транзакций, аналогов, оперирующих типом xid8 (Томас Манро)

    Старые функции, оперирующие типом xid, сохранены для обратной совместимости.

  • Реализация в функциях get_bit() и set_bit() возможности обращаться к битам за пределами первых 256 Мбайт значения bytea (Мувад Ли)

  • Возможность использования функций рекомендательных блокировок в некоторых выполняемых параллельно операциях (Том Лейн)

  • Добавление возможности удалить зависимость объекта от расширения (Альваро Эррера)

    Для этого предусмотрен синтаксис ALTER .. NO DEPENDS ON. Объектом в данном случае может быть функция, материализованное представление, индекс или триггер.

E.8.3.6. PL/pgSQL

  • Ускорение выполнения простых выражений PL/pgSQL (Том Лейн, Амит Ланготе)

  • Ускорение выполнения функций на PL/pgSQL, в которых используются постоянные выражения (Константин Книжник)

E.8.3.7. Клиентские интерфейсы

  • Предоставление клиентам libpq возможности затребовать связывание каналов для шифрованных соединений (Джефф Девис)

    Добавленный в libpq параметр соединения channel_binding требует от другой стороны TLS-соединения доказательства того, что она знает пароль пользователя. Это предотвращает атаки с посредником.

  • Добавление в libpq параметров соединения, задающих минимальную и максимальную версию TLS, допустимую для шифрования подключений (Даниэль Густафссон)

    Новые параметры называются ssl_min_protocol_version и ssl_max_protocol_version, соответственно. Минимальной допустимой версией TLS теперь считается 1.2 (тем самым меняется поведение по сравнению с предыдущими выпусками).

  • Добавление возможности указания паролей, разблокирующих клиентские сертификаты (Крейг Рингер, Эндрю Дунстан)

    Для этого предназначен параметр подключения libpq sslpassword.

  • Поддержка в libpq клиентских сертификатов в кодировке DER (Крейг Рингер, Эндрю Дунстан)

  • Исправление работы указания EXEC SQL elif в ecpg (Том Лейн)

    Ранее оно работало как endif с последующим ifdef, так что предыдущее попадание в положительную ветвь в том же if не исключало попадание в ветвь elif или последующие ветви.

E.8.3.8. Клиентские приложения

E.8.3.8.1. psql
  • Добавление признака состояния транзакции (%x) в стандартные приглашения psql (Вик Фиринг)

  • Возможность задать дополнительное приглашение psql, которое будет пустым, но его ширина будет совпадать с шириной основного (Томас Манро)

    Для этого в переменной PROMPT2 нужно указать %w.

  • Возможность изменить в командах psql \g и \gx параметры вывода \pset на время выполнения данной команды (Том Лейн)

    Это позволяет, например, записать \g (expand=on), что будет равнозначно команде \gx.

  • Добавление в psql команд для вывода информации о классах операторов и семействах операторов (Сергей Черкашин, Никита Глухов, Александр Коротков)

    А именно, добавлены команды \dAc, \dAf, \dAo и \dAp.

  • Отображение характеристики хранения отношения в команде psql \dt+ и связанных командах (Давид Феттер)

    В режиме детализации теперь будет показываться, является ли отношение (таблица/индекс/представление) постоянным, временным или нежурналируемым.

  • Улучшение вывода команды psql \d для TOAST-таблиц (Джастин Призби)

  • Усовершенствование вывода в psql после команды \e (Том Лейн)

    Теперь при выходе из редактора, если введённый запрос завершается не командой \g или точкой с запятой, будет выводиться содержимое буфера запроса.

  • Добавление в psql команды \warn (Давид Феттер)

    Эта команда выводит текст подобно \echo, но не в stdout, а в stderr.

  • Добавление ссылки на домашнюю страницу PostgreSQL в справку, выводимую с ключом --help (Питер Эйзентраут)

E.8.3.8.2. pgbench
  • Добавление в pgbench возможности сделать таблицу «accounts» секционированной (Фабьен Коэльо)

    Благодаря этому можно протестировать производительность механизма секционирования.

  • Добавление в pgbench команды \aset, подобной \gset, но рассчитанной на несколько запросов (Фабьен Коэльо)

  • Реализация в pgbench возможности генерировать начальные данные на стороне сервера, а не на стороне клиента (Фабьен Коэльо)

  • Добавление в pgbench вывода содержимого скрипта с аргументом --show-script (Фабьен Коэльо)

E.8.3.9. Серверные приложения

  • Формирование манифестов копий при выполнении базового копирования, а также проверка копий по этим манифестам (Роберт Хаас)

    Новое средство pg_verifybackup, предназначенное для проверки копий.

  • Выполнение в pg_basebackup расчёта общего размера копии по умолчанию (Фудзии Масао)

    Полученный результат позволяет показать процесс копирования в pg_stat_progress_basebackup. Если это не требуется, этот расчёт можно отключить, воспользовавшись аргументом --no-estimate-size. Ранее этот расчёт производился только при добавлении аргумента --progress.

  • Добавление в pg_rewind ключа для формирования конфигурации ведомого сервера (Пол Гуо, Джимми Йи, Ашвин Агравал)

    Новый ключ --write-recovery-conf соответствует одноименному ключу pg_basebackup.

  • Возможность использования в pg_rewind команды restore_command, заданной в целевом кластере, для получения необходимых сегментов WAL (Алексей Кондратов)

    Новое поведение включается ключом -c/--restore-target-wal.

  • Автоматический запуск в pg_rewind процедуры восстановления согласованности до начала синхронизации состояния (Пол Гуо, Джимми Йи, Ашвин Агравал)

    Отключить эту процедуру позволяет ключ --no-ensure-shutdown.

  • Добавление подробной информации о PREPARE TRANSACTION в вывод pg_waldump (Фудзии Масао)

  • Добавление в pg_waldump ключа --quiet, отключающего вывод всех сообщений, кроме ошибок (Андрес Фройнд, Роберт Хаас)

  • Добавление в pg_dump ключа --include-foreign-data для выгрузки данных со сторонних серверов (Луис М. Карриль)

  • Поддержка параллельного выполнения команд очистки в программе vacuumdb (Масахико Савада)

    Этот режим включается новым аргументом --parallel.

  • Поддержка выполнения операций reindexdb в несколько потоков (Жюльен Руо)

    Параллельный режим включается новым параметром --jobs.

  • Реализация в dropdb возможности принудительно удалить базу, отключив от неё пользователей (Павел Стехуле)

    Для такого удаления предназначен ключ -f.

  • Ликвидация ключей --adduser и --no-adduser команды createuser (Александр Лахин)

    Вместо них уже очень давно поддерживаются ключи --superuser и --no-superuser.

  • Использование каталога, в котором находится запущенная программа pg_upgrade, в качестве значения по умолчанию параметра --new-bindir (Даниэль Густафссон)

E.8.3.10. Документация

  • Добавление в документацию глоссария (Кори Хинкер, Юрген Пуртц, Роджер Гаркави, Альваро Эррера)

  • Переформатирование таблиц с информацией о функциях и операторах для улучшения визуального восприятия (Том Лейн)

  • Переход к использованию DocBook 4.5 (Питер Эйзентраут)

E.8.3.11. Исходный код

  • Обеспечение поддержки сборки в Visual Studio 2019 (Харибабу Комми)

  • Добавление поддержки MSYS2 (Питер Эйзентраут)

  • Добавление ассемблерного кода реализации compare_exchange и fetch_add для компиляторов на платформе Power PC (Ной Миш)

  • Обновление словарей стеммера Snowball, используемых при полнотекстовом поиске (Панайотис Мавройоргос)

    В результате добавился стеммер для греческого языка, а также обновились стеммеры для датского и французского языков.

  • Ликвидация поддержки Windows 2000 (Микаэль Пакье)

  • Прекращение поддержки отличных от ELF форматов двоичных файлов в системах BSD (Питер Эйзентраут)

  • Прекращение поддержки Python версии 2.5.X и более старых (Питер Эйзентраут)

  • Прекращение поддержки OpenSSL версии 0.9.8 и 1.0.0 (Микаэль Пакье)

  • Удаление параметров configure --disable-float8-byval и --disable-float4-byval (Питер Эйзентраут)

    Они были нужны для совместимости с некоторыми функциями на C, имеющими API версии 0, но такие функции уже не поддерживаются.

  • Передача строки запроса в функции-обработчики, вызываемые планировщиком (Паскаль Легран, Жюльен Руо)

  • Возможность подключения обработчиков, вызываемых при выполнении TRUNCATE (Юлиан Ходорковский)

  • Возможность подключения обработчиков, вызываемых при инициализации TLS (Эндрю Дунстан)

  • Возможность сборки без предопределённого каталога Unix-сокетов (Питер Эйзентраут)

  • Уменьшение вероятности конфликта при выборе ключей ресурсов SysV на платформах Unix (Том Лейн)

  • Использование функций операционной системы для надёжной очистки памяти, содержащей конфиденциальную информацию (Питер Эйзентраут)

    Таким образом очищается область памяти, содержащая пароль.

  • Добавление скрипта headerscheck для проверки совместимости заголовочных файлов C (Том Лейн)

  • Реализация внутренних списков в виде массивов, а не в виде цепочки элементов (Том Лейн)

    Это способствует увеличению быстродействия запросов, обращающихся ко множеству объектов.

  • Изменение API функции TS_execute() (Том Лейн, Павел Борисов)

    Обработчики TS_execute теперь должны оперировать троичной логикой (да/нет/возможно). Кроме того, теперь по умолчанию точно вычисляются запросы с отрицанием.

E.8.3.12. Дополнительные модули

  • Возможность описания доверенных расширений (Том Лейн)

    Такие расширения теперь могут устанавливаться в базу данных обычными пользователями, имеющими только право CREATE на уровне базы данных. В результате этого изменения был также удалён системный каталог pg_pltemplate.

  • Предоставление обычным пользователям возможности подключаться к сторонним серверам через postgres_fdw, не указывая пароль (Крейг Рингер)

    Для этого суперпользователь может задать в сопоставлении пользователей параметр password_required, равный false. При этом необходимо позаботиться о том, чтобы обычные пользователи не могли использовать учётные данные суперпользователей для подключения к стороннему серверу.

  • Поддержка в postgres_fdw аутентификации по сертификатам (Крейг Рингер)

    При этом разные пользователи могут использовать разные сертификаты.

  • Возможность ограничения доступа к команде TRUNCATE средствами sepgsql (Юлиан Ходорковский)

  • Добавление расширения bool_plperl, которое преобразует логические значения SQL в логические значения PL/Perl и наоборот (Иван Панченко)

  • Реализация в pg_stat_statements отдельной обработки указания FOR UPDATE в командах SELECT ... FOR UPDATE (Эндрю Гирт, Вик Фиринг)

  • Реализация в pg_stat_statements возможности отслеживать время планирования запросов (Жюльен Руо, Паскаль Легран, Томас Манро, Фудзии Масао)

    Ранее отслеживалось только время выполнения.

  • Исправление синтаксиса lquery в ltree для реализации более логичного поведения отрицания (!) (Филип Рембялковский, Том Лейн, Никита Глухов)

    Также в запросах без * теперь можно указать интервал, ограничивающий число вхождений ({}).

  • Добавление поддержки двоичного ввода/вывода для типов ltree, lquery и ltxtquery (Нино Флорис)

  • Добавление в dict_int возможности игнорировать знак у целых чисел (Джефф Джейнс)

  • Добавление в adminpack функции pg_file_sync() для синхронизации файла с файловой системой (Фудзии Масао)

  • Добавление в pageinspect функций для вывода значений t_infomask/t_infomask2 в понятном человеку виде (Крейг Рингер, Савада Масахико, Микаэль Пакье)

  • Добавление в вывод pageinspect столбцов с информацией об исключении дубликатов в индексах-B-деревьях (Питер Гейган)

E.8.4. Благодарственный список

Перечисленные ниже (в алфавитном порядке) лица сделали вклад в этот выпуск, разрабатывая, совершенствуя и рецензируя код, принимая правки, проводя тестирование или сообщая о проблемах.

Абхиджит Менон-Сен (Abhijit Menon-Sen)
Адам Ли (Adam Lee)
Адам Скотт (Adam Scott)
Аде Хэйуорд (Adé Heyward)
Адриен Найрат (Adrien Nayrat)
Айзек Морленд (Isaac Morland)
Аластер Маккинли (Alastair McKinley)
Алекс Мейси (Alex Macy)
Александр Акципетров (Alex Aktsipetrov)
Александр Коротков (Alexander Korotkov)
Александр Кузьменков (Alexander Kuzmenkov)
Александр Кукушкин (Alexander Kukushkin)
Александр Лахин (Alexander Lakhin)
Александр Парфёнов (Aleksandr Parfenov)
Александр Шульгин (Alex Shulgin)
Алексей Баштанов (Alexey Bashtanov)
Алексей Клюкин (Oleksii Kliukin)
Алексей Кондратов (Alexey Kondratov)
Альваро Эррера (Álvaro Herrera)
Амит Капила (Amit Kapila)
Амит Ланготе (Amit Langote)
Амит Хандекар (Amit Khandekar)
Амул Сул (Amul Sul)
Анастасия Лубенникова (Anastasia Lubennikova)
Андреас Джозеф Крог (Andreas Joseph Krogh)
Андреас Зельтенрейх (Andreas Seltenreich)
Андреас Карлссон (Andreas Karlsson)
Андреас Кунерт (Andreas Kunert)
Андрей Билле (Andrew Bille)
Андрей Бородин (Andrey Borodin)
Андрей Зубков (Andrei Zubkov)
Андрей Клычков (Andrey Klychkov)
Андрей Лепихов (Andrey Lepikhov)
Андрес Фройнд (Andres Freund)
Анна Акентьева (Anna Akenteva)
Анна Эндо (Anna Endo)
Антон Власов (Anton Vlasov)
Антони Новосьен (Anthony Nowocien)
Антонин Хоуска (Antonin Houska)
Антс Аасма (Ants Aasma)
Арне Роланд (Arne Roland)
Арнольд Мюллер (Arnold Müller)
Арсений Шер (Arseny Sher)
Артур Закиров (Artur Zakirov)
Артур Насименту (Arthur Nascimento)
Асим Правин (Asim Praveen)
Асиф Рехман (Asif Rehman)
Атсуши Торикоши (Atsushi Torikoshi)
Аугустинас Йокубаускас (Augustinas Jokubauskas)
Ахсан Хади (Ahsan Hadi)
Ашвин Агравал (Ashwin Agrawal)
Ашутош Бапат (Ashutosh Bapat)
Ашутош Шарма (Ashutosh Sharma)
Бейзил Бурк (Basil Bourque)
Бен Корнет (Ben Cornett)
Бенджи Гиллам (Benjie Gillam)
Бенуа Лобро (Benoît Lobréau)
Бернд Хелмле (Bernd Helmle)
Бина Эмерсон (Beena Emerson)
Бинго Бао (Binguo Bao)
Брайан Вильямс (Brian Williams)
Брандур Лич (Brandur Leach)
Брент Бейтс (Brent Bates)
Брэд Дейонг (Brad DeJong)
Брюс Момджян (Bruce Momjian)
Бхарат Рупиредди (Bharath Rupireddy)
Бхаргав Каминени (Bhargav Kamineni)
Вайет Алт (Wyatt Alt)
Вигнеш Си (Vignesh C)
Вик Фиринг (Vik Fearing)
Виктор Вагнер (Victor Wagner)
Виктор Егоров (Victor Yegorov)
Вилл Лайнвебер (Will Leinweber)
Вильям Кровелл (William Crowell)
Винай Банакар (Vinay Banakar)
Владимир Лесков (Vladimir Leskov)
Владимир Ситников (Vladimir Sitnikov)
Вячеслав Макаров (Vyacheslav Makarov)
Вячеслав Шаблистый (Vyacheslav Shablistyy)
Георгиос Коколатос (Georgios Kokolatos)
Гийом Леларж (Guillaume Lelarge)
Грег Нанкарроу (Greg Nancarrow)
Григорий Смолкин (Grigory Smolkin)
Гуаньчэн Ло (Guancheng Luo)
Давид Феттер (David Fetter)
Давиндер Сингх (Davinder Singh)
Дагфинн Ильмари Маннсакер (Dagfinn Ilmari Mannsåker)
Даниель Вестерман (Daniel Westermann)
Даниэль Верите (Daniel Vérité)
Даниэль Густафссон (Daniel Gustafsson)
Даниэль Фиори (Daniel Fiori)
Дейв Крамер (Dave Cramer)
Денис Стучалин (Denis Stuchalin)
Дент Джон (Dent John)
Джастин Кинг (Justin King)
Джастин Призби (Justin Pryzby)
Джеймс Грей (James Gray)
Джеймс Информ (James Inform)
Джеймс Коулман (James Coleman)
Джеймс Лукас (James Lucas)
Джеймс Хантер (James Hunter)
Джереми Смит (Jeremy Smith)
Джереми Шнайдер (Jeremy Schneider)
Джереми Эванс (Jeremy Evans)
Джерри Сиверс (Jerry Sievers)
Джеспер Педерсен (Jesper Pedersen)
Джесси Кинкед (Jesse Kinkead)
Джесси Чжан (Jesse Zhang)
Джефф Девис (Jeff Davis)
Джефф Джейнс (Jeff Janes)
Джи Чжан (Jie Zhang)
Дживан Ладхе (Jeevan Ladhe)
Дживан Чок (Jeevan Chalke)
Джим Нэсби (Jim Nasby)
Джимми Йи (Jimmy Yih)
Джо Конвей (Joe Conway)
Джон Нейлор (John Naylor)
Джон Сюй (John Hsu)
Джонатан С Кац (Jonathan S. Katz)
Дидье Готрон (Didier Gautheron)
Дилип Кумар (Dilip Kumar)
Дин Рашид (Dean Rasheed)
Дмитрий Белявский (Dmitry Belyavsky)
Дмитрий Долгов (Dmitry Dolgov)
Дмитрий Иванов (Dmitry Ivanov)
Дмитрий Тельпт (Dmitry Telpt)
Дмитрий Успенский (Dmitry Uspenskiy)
Доминик Чарнота (Dominik Czarnota)
Донмин Лю (Dongming Liu)
Дорофей Пролесковский (Darafei Praliaskouski)
Дэвид Гилман (David Gilman)
Дэвид Дж. Джонстон (David G. Johnston)
Дэвид Кристенсен (David Christensen)
Дэвид Роули (David Rowley)
Дэвид Стил (David Steele)
Дэвид Харпер (David Harper)
Дэвид Чжан (David Zhang)
Дэрил Вэйкотт (Daryl Waycott)
Евгений Коньков (Eugen Konkov)
Ёсикадзу Имаи (Yoshikazu Imai)
Жеан-Гийом де Рорте (Jehan-Guillaume de Rorthais)
Женхуа Цай (ZhenHua Cai)
Жиль Даролд (Gilles Darold)
Жобен Августин (Jobin Augustine)
Жорж Густаву Роша (Jorge Gustavo Rocha)
Жуй Хай Цзян (Rui Hai Jiang)
Жюльен Руо (Julien Rouhaud)
И Хуан (Yi Huang)
Ибрар Ахмед (Ibrar Ahmed)
Иван Картышов (Ivan Kartyshov)
Иван Панченко (Ivan Panchenko)
Иван Серджо Боргоново (Ivan Sergio Borgonovo)
Игон Ху (Yigong Hu)
Ильдар Мусин (Ildar Musin)
Инсон Мун (Insung Moon)
Иренеуш Плюта (Ireneusz Pluta)
Итан Уолдо (Ethan Waldo)
Иэн Барвик (Ian Barwick)
Йоанн Ла Канчеллера (Yoann La Cancellera)
Йозеф Нахмиас (Joseph Nahmias)
Йозеф Шиманек (Josef Šimánek)
Йон Йенсен (Jon Jensen)
Кайл Кингсбери (Kyle Kingsbury)
Камерон Эзелл (Cameron Ezell)
Карл О. Пинц (Karl O. Pinc)
Квентин Рамо (Quentin Rameau)
Келли Минь (Kelly Min)
Кен Танцер (Ken Tanzer)
Кирилл Бычик (Kirill Bychik)
Кирк Джемисон (Kirk Jamison)
Кит Фиске (Keith Fiske)
Константин Книжник (Konstantin Knizhnik)
Кори Хинкер (Corey Huinker)
Крейг Рингер (Craig Ringer)
Крис Бенди (Chris Bandy)
Крис Трэверс (Chris Travers)
Кристоф Берг (Christoph Berg)
Кристоф Куртуа (Christophe Courtois)
Кунтал Гхош (Kuntal Ghosh)
Кэйсукэ Курода (Keisuke Kuroda)
Кэри Хуан (Cary Huang)
Кётаро Хоригути (Kyotaro Horiguchi)
Ларс Канис (Lars Kanis)
Лауренц Альбе (Laurenz Albe)
Лейф Гуннар Эрландсен (Leif Gunnar Erlandsen)
Ли Япинь (Li Japin)
Луис М. Карриль (Luis M. Carril)
Лукас Виечелли (Lucas Viecelli)
Лукаш Соботка (Lukáš Sobotka)
Людмила Мантрова (Liudmila Mantrova)
Магнус Хагандер (Magnus Hagander)
Майк Пальмиотто (Mike Palmiotto)
Майкл Ло (Michael Luo)
Максанс Алуш (Maxence Ahlouche)
Мануэль Риггер (Manuel Rigger)
Марина Полякова (Marina Polyakova)
Марк Вон (Mark Wong)
Марк Дилгер (Mark Dilger)
Марк Манро (Marc Munro)
Марко Тииккая (Marko Tiikkaja)
Маркус Винанд (Markus Winand)
Маркуш Давид (Marcos David)
Мартейн Ван Остерхаут (Martijn van Oosterhout)
Марти Раудсепп (Marti Raudsepp)
Масао Фудзии (Masao Fujii)
Масахико Савада (Masahiko Sawada)
Масахиро Икеда (Masahiro Ikeda)
Матео Беккати (Matteo Beccati)
Матеуш Гузик (Mateusz Guzik)
Махадеван Рамачандран (Mahadevan Ramachandran)
Махендра Сингх Талор (Mahendra Singh Thalor)
Мачик Сакрейда (Maciek Sakrejda)
Мелани Плейгман (Melanie Plageman)
Микаэль Пакье (Michael Paquier)
Митхун Сай (Mithun Cy)
Михаил Николаев (Michail Nikolaev)
Михаэль Банк (Michael Banck)
Михаэль Мескес (Michael Meskes)
Мувад Ли (Movead Li)
Мэтт Джибсон (Matt Jibson)
Назлы Уур Кёйлюоглу (Nazli Ugur Koyluoglu)
Натан Боссарт (Nathan Bossart)
Неха Шарма (Neha Sharma)
Никита Глухов (Nikita Glukhov)
Никола Конту (Nicola Contu)
Николай Шаплов (Nikolay Shaplov)
Николас Альварес (Nicolás Alvarez)
Никхил Сонтакке (Nikhil Sontakke)
Нино Флорис (Nino Floris)
Ной Миш (Noah Misch)
Нориёси Синода (Noriyoshi Shinoda)
Олег Бартунов (Oleg Bartunov)
Олег Самойлов (Oleg Samoilov)
Ондрей Йирман (Ondrej Jirman)
Остин Дренски (Austin Drenski)
Паван Деоласи (Pavan Deolasee)
Павел Борисов (Pavel Borisov)
Павел Лузанов (Pavel Luzanov)
Павел Сиваш (Paul Sivash)
Павел Стехуле (Pavel Stehule)
Павел Судеревский (Pavel Suderevsky)
Панайотис Мавройоргос (Panagiotis Mavrogiorgos)
Паскаль Легран (Pascal Legrand)
Патрик Макхарди (Patrick McHardy)
Петер Биллен (Peter Billen)
Петр Желинек (Petr Jelínek)
Питер Гейган (Peter Geoghegan)
Питер Смит (Peter Smith)
Питер Эйзентраут (Peter Eisentraut)
Пол Гуо (Paul Guo)
Пол Рамсей (Paul Ramsey)
Пол Спенсер (Paul Spencer)
Пол Юнгвирт (Paul Jungwirth)
Прабхат Саху (Prabhat Sahu)
Пьер Дюкроке (Pierre Ducroquet)
Пьер Жиро (Pierre Giraud)
Пэйфэн Цю (Peifeng Qiu)
Пэнчжоу Тан (Pengzhou Tang)
Пётр Влодарчик (Piotr Wlodarczyk)
Пётр Габриэль Косински (Piotr Gabriel Kosinski)
Пётр Фёдоров (Petr Fedorov)
Радж Мохите (Raj Mohite)
Раджкумар Рагхуванши (Rajkumar Raghuwanshi)
Райан Ламберт (Ryan Lambert)
Раманараяна Мусунуру (Ramanarayana Musunuru)
Ранье Вилела (Ranier Vilela)
Рареш Салкудян (Rares Salcudean)
Рауль Марин Родригес (Raúl Marín Rodríguez)
Рафаэль Кастро (Rafael Castro)
Рафия Сабих (Rafia Sabih)
Реймонд Мартин (Raymond Martin)
Рейо Сухонен (Reijo Suhonen)
Ричард Гуо (Richard Guo)
Роберт Калерт (Robert Kahlert)
Роберт Трит (Robert Treat)
Роберт Форд (Robert Ford)
Роберт Хаас (Robert Haas)
Робин Абби (Robin Abbi)
Робинс Таракан (Robins Tharakan)
Роджер Гаркави (Roger Harkavy)
Роман Пешкуров (Roman Peshkurov)
Руи ДеСуоза (Rui DeSousa)
Рушаб Латиа (Rushabh Lathia)
Рёхэй Такахаси (Ryohei Takahashi)
Саймон Риггс (Simon Riggs)
Сергей Агалаков (Sergei Agalakov)
Сергей Корнилов (Sergei Kornilov)
Сергей Черкашин (Sergey Cherkashin)
Сероп Саркуни (Sehrope Sarkuni)
Скотт Райб (Scott Ribe)
Славомир Ходницки (Slawomir Chodnicki)
Соумйадип Чакраборти (Soumyadeep Chakraborty)
Стефан Лорек (Stéphane Lorek)
Стив Роджерсон (Steve Rogerson)
Стивен Винфилд (Steven Winfield)
Стивен Фрост (Stephen Frost)
Сурадж Хараге (Suraj Kharage)
Сурафел Темесген (Surafel Temesgen)
Таканори Асаба (Takanori Asaba)
Такао Фудзии (Takao Fujii)
Такаюки Цунакава (Takayuki Tsunakawa)
Такума Хосиай (Takuma Hoshiai)
Там Нгуен (Tham Nguyen)
Тацуо Исии (Tatsuo Ishii)
Тацуро Ямада (Tatsuro Yamada)
Тацухито Касахара (Tatsuhito Kasahara)
Тейлор Веселы (Taylor Vesely)
Тибо Мадлен (Thibaut Madelaine)
Тим Кларк (Tim Clarke)
Тим Мёльман (Tim Möhlmann)
Том Браун (Thom Brown)
Том Готтфрид (Tom Gottfried)
Том Лейн (Tom Lane)
Том Эллис (Tom Ellis)
Томас Келлерер (Thomas Kellerer)
Томас Манро (Thomas Munro)
Томаш Вондра (Tomas Vondra)
Туомас Лейкола (Tuomas Leikola)
Тушар Ахуджа (Tushar Ahuja)
Тьягу Анастасиу (Tiago Anastacio)
Фабрицио де Ройес Мелло (Fabrízio de Royes Mello)
Фабьен Коэльо (Fabien Coelho)
Феликс Лехнер (Felix Lechner)
Фил Байер (Phil Bayer)
Филип Рембялковский (Filip Rembialkowski)
Филип Семанчук (Philip Semanchuk)
Филип Януш (Filip Janus)
Филипп Бодуэн (Philippe Beaudoin)
Франк Ганьепен (Frank Gagnepain)
Фёдор Сигаев (Teodor Sigaev)
Хади Мошаеди (Hadi Moshayedi)
Хайин Тан (Haiying Tang)
Хайме Казанова (Jaime Casanova)
Хамид Ахтар (Hamid Akhtar)
Ханс Бушман (Hans Buschmann)
Хао Ву (Hao Wu)
Харибабу Комми (Haribabu Kommi)
Харука Такацука (Haruka Takatsuka)
Хейкки Линнакангас (Heikki Linnakangas)
Химаншу Упадхьяя (Himanshu Upadhyaya)
Хиронобу Судзуки (Hironobu Suzuki)
Хит Лорд (Heath Lord)
Хуан Хосе Сантамария Флеча (Juan José Santamaría Flecha)
Хью Ван (Hugh Wang)
Хью Макмастер (Hugh McMaster)
Хью Раналли (Hugh Ranalli)
Цзянь Чжан (Jian Zhang)
Цуйпин Линь (Cuiping Lin)
Цюань Цзунлян (Quan Zongliang)
Чарльз Оффенбахер (Charles Offenbacher)
Ченьян Лу (Chenyang Lu)
Чепмен Флэк (Chapman Flack)
Чэнь Хуацзюнь (Chen Huajun)
Шеньхао Ван (Shenhao Wang)
Шон Ван (Shawn Wang)
Шон Дебнатх (Shawn Debnath)
Шон Фаррел (Sean Farrell)
Шэй Роджански (Shay Rojansky)
Эд Морли (Ed Morley)
Эдмунд Хорнер (Edmund Horner)
Эйлер Тавейра (Euler Taveira)
Эмре Хасегели (Emre Hasegeli)
Эндрю Гирт (Andrew Gierth)
Эндрю Дунстан (Andrew Dunstan)
Эрвин Брандштеттер (Erwin Brandstetter)
Эрик Гиллум (Eric Gillum)
Эрик Рижкерс (Erik Rijkers)
Эцуро Фудзита (Etsuro Fujita)
Ю Кимура (Yu Kimura)
Юго Нагата (Yugo Nagata)
Юзуко Хосоя (Yuzuko Hosoya)
Юлиан Бэкес (Julian Backes)
Юлиан Ходорковский (Yuli Khodorkovskiy)
Юрген Пуртц (Jürgen Purtz)
Юсукэ Эгашира (Yusuke Egashira)
Юя Ватари (Yuya Watari)
Ян Мусслер (Jan Mussler)
Ян Сяо (Yang Xiao)
Ярослав Сивы (Jaroslav Sivy)
Ярослав Щёкин (Yaroslav Schekin)