E.2. Выпуск 10

Дата выпуска: 2017-10-05

E.2.1. Обзор

В число ключевых усовершенствований PostgreSQL 10 входят:

  • Логическая репликация по схеме публикации/подписки

  • Декларативное секционирование таблиц

  • Улучшение распараллеливания запросов

  • Значительное увеличение общей производительности

  • Более сильная защита паролей с использованием SCRAM-SHA-256

  • Улучшенные средства мониторинга и управления

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

E.2.2. Миграция на версию 10

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

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

  • После обновления с помощью pg_upgrade с любой предыдущей основной версии PostgreSQL необходимо перестроить хеш-индексы (Митхун Ки, Роберт Хаас, Амит Капила)

    Необходимость данного требования продиктована значительным усовершенствованием механизма хеш-индексов. Для облегчения задачи переиндексации pg_upgrade создаст вспомогательный скрипт.

  • Переименование каталога с журналом предзаписи из pg_xlog в pg_wal, а также переименование каталога с информацией о состоянии транзакций из pg_clog в pg_xact (Мишель Пакье)

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

  • Замена в именах функций SQL, утилит и параметров всех упоминаний «xlog» на «wal» (Роберт Хаас)

    Например, имя pg_switch_xlog() поменялось на pg_switch_wal(), pg_receivexlog — на pg_receivewal, а --xlogdir — на --waldir. Это было сделано вместе с переименованием каталога pg_xlog для согласованности; и вообще термин «xlog» теперь нигде не может встретиться пользователю.

  • Замена в связанных с WAL функциях и представлениях location на lsn (Дэвид Роули)

    Ранее имело место несогласованное употребление обоих терминов.

  • Изменение реализации функций, возвращающих множества, в списке SELECT (Андрес Фройнд)

    Функции, возвращающие множества, теперь вычисляются до вычисления скалярных выражений в списке SELECT, практически так же, как если бы они были помещены в предложение LATERAL FROM. Это даёт более понятное поведение в случаях, когда присутствуют несколько таких функций. Если они возвращают разное количество строк, все результаты дополняются до наибольшего количества строк значениями NULL. Ранее результаты обрабатывались в цикле, пока все функции не завершались, и в результате получалось количество строк, равное наименьшему общему кратному периодов функций. Кроме того, функции, возвращающие множества, теперь нельзя использовать в конструкциях CASE и COALESCE. За дополнительными сведениями обратитесь к Подразделу 37.4.8.

  • Использование стандартного синтаксиса конструктора строки в UPDATE ... SET (список_столбцов) = конструктор_строки (Том Лейн)

    Теперь конструктор_строки может начинаться со слова ROW; ранее его надо было опускать. Если в списке_столбцов фигурирует имя только одного столбца, конструктор_строки должен использовать ключевое слово ROW, так как иначе он не будет корректным конструктором строки, а будет восприниматься как выражение в скобках. Также запись имя_таблицы.* в конструкторе_строки теперь разворачивается в набор столбцов, как и в других случаях использования конструктора_строки.

  • Когда ALTER TABLE ... ADD PRIMARY KEY помечает столбцы как NOT NULL, это изменение теперь распространяется также на дочерние таблицы в иерархии наследования (Мишель Пакье)

  • Предотвращение срабатывания триггеров уровня оператора более одного раза для одного оператора (Том Лейн)

    В случаях, когда пишущие CTE изменяли одну таблицу, изменяемую внешним оператором либо другими пишущими CTE, триггеры BEFORE STATEMENT и AFTER STATEMENT вызывались неоднократно. Также, если в таблице были определены триггеры уровня оператора, в результате действий для обеспечения целостности внешнего ключа (например, ON DELETE CASCADE), они могли вызываться несколько раз для одного внешнего SQL-оператора. Это поведение противоречит стандарту SQL и было исправлено.

  • Перемещение полей метаданных последовательностей в новый системный каталог pg_sequence (Питер Эйзентраут)

    Отношение последовательности содержит теперь только поля, которые могут быть изменены функцией nextval(), то есть last_value, log_cnt и is_called. Другие свойства последовательности, такие как начальное значение и шаг увеличения, сохраняются в соответствующей строке в каталоге pg_sequence. Действие ALTER SEQUENCE теперь полностью транзакционное и, как следствие, блокирует последовательность до фиксации транзакции. Функции nextval() и setval() остаются нетранзакционными.

    Основная несовместимость, привнесённая этим изменением, состоит в том, что из отношения последовательности теперь можно прочитать только три поля, перечисленные выше. Чтобы получить другие свойства последовательности, приложения должны обратиться к pg_sequence. Также для этого можно использовать новое системное представление pg_sequences; оно выдаёт столбцы с именами, более подходящими для существующего кода.

    Переработан и вывод команды psql \d для последовательностей.

  • Передача по умолчанию программой pg_basebackup данных WAL, необходимых для восстановления резервной копии (Магнус Хагандер)

    При этом в pg_basebackup подразумеваемое значение -X/--wal-method меняется на stream. Для воспроизведения старого поведения был добавлен вариант значения none. Параметр pg_basebackup -x был удалён (используйте вместо него -X fetch).

  • Изменение записей логической репликации в pg_hba.conf (Питер Эйзентраут)

    В предыдущих версиях для подключения логической репликации требовалось указать replication в столбце базы данных. С этого выпуска логической репликации соответствует обычная запись с именем базы данных или ключевым словом, например, all. Для физической репликации по-прежнему используется ключевое слово replication. Так как встроенная логическая репликация появилась только в этом выпуске, это изменение может затронуть только пользователей сторонних средств логической репликации.

  • Все действия в pg_ctl по умолчанию должны ожидать завершения операции (Питер Эйзентраут)

    Ранее некоторые действия pg_ctl не ждали завершения и для ожидания требовалось использовать ключ -w.

  • Изменение значения по умолчанию серверного параметра log_directory с pg_log на log (Андреас Карлссон)

  • Добавление параметра конфигурации ssl_dh_params_file для указания имени файла с нестандартными параметрами OpenSSL DH (Хейкки Линнакангас)

    Тем самым заменяется жёстко заданное и недокументированное имя файла dh1024.pem. Заметьте, что файл dh1024.pem по умолчанию больше не обрабатывается; вы должны задать этот параметр, если хотите использовать свои параметры DH.

  • Увеличение размера стандартных параметров DH, используемых для эфемерных DH-шифров OpenSSL, до 2048 бит (Хейкки Линнакангас)

    Размер предопределённых в коде параметров DH был увеличен с 1024 до 2048 бит, так что обмен ключами DH стал более устойчивым к подбору шифра. Однако некоторые старые реализации SSL, в частности некоторые ревизии Java Runtime Environment версии 6, не принимают параметры DH длиннее 1024 бит и, таким образом, не смогут подключиться через SSL. Если вам необходимо поддерживать такие старые клиенты, вы можете использовать нестандартные параметры DH размером 1024 бита вместо предопределённых параметров по умолчанию. См. ssl_dh_params_file.

  • Ликвидация возможности хранения незашифрованных паролей на сервере (Хейкки Линнакангас)

    Серверный параметр password_encryption больше не поддерживает значения off и plain. Вариант UNENCRYPTED также теперь не поддерживается в командах CREATE/ALTER USER ... PASSWORD. Аналогично был удалён ключ --unencrypted команды createuser. Незашифрованные пароли, перенесённые из старых версий, в этой версии будут храниться в зашифрованном виде. Значением по умолчанию параметра password_encryption остаётся md5.

  • Добавление серверных параметров min_parallel_table_scan_size и min_parallel_index_scan_size для управления параллельными запросами (Амит Капила, Роберт Хаас)

    Они заменяют переменную min_parallel_relation_size, которая была слишком общей.

  • Не заключённый в кавычки текст в shared_preload_libraries и связанных серверных параметрах не должен переводиться в нижний регистр (Куэль Чжо)

    Эти параметры на самом деле представляют собой списки имён файлов, но ранее они воспринимались как списки SQL-идентификаторов и обрабатывались по другим правилам.

  • Удаление серверного параметра sql_inheritance (Роберт Хаас)

    При выключенном значении этого параметра запросы, обращающиеся к родительским таблицам, перестают учитывать дочерние. Однако стандарт SQL требует, чтобы они учитывались, и это поведение было принято по умолчанию в PostgreSQL 7.1.

  • Реализация возможности передавать многомерные массивы в функции на PL/Python и возвращать вложенные списки Python (Алексей Грищенко, Дэйв Крамер, Хейкки Линнакангас)

    Это изменение потребовало нарушить обратную совместимость в части обработки массивов составных типов в PL/Python. Раньше можно было вернуть массив составных типов как [[col1, col2], [col1, col2]]; но теперь это будет интерпретироваться как двухмерный массив. Составные типы в массивах для однозначности должны возвращаться теперь в виде кортежей Python, а не в виде списков. То есть предыдущую запись нужно заменить на [(col1, col2), (col1, col2)].

  • Удаление механизма автозагрузки «модулей» PL/Tcl (Том Лейн)

    На замену этой функциональности пришли новые серверные параметры pltcl.start_proc и pltclu.start_proc, которые проще в использовании и дают возможности, подобные имеющимся в других языках программирования.

  • Ликвидация поддержки выгрузки данных с серверов до 8.0 утилитами pg_dump/pg_dumpall (Том Лейн)

    Пользователям, которым нужно выгрузить данные с серверов до 8.0, остаётся использовать dump из PostgreSQL версии 9.6 или старее. Выгруженные этими версиями данные должны успешно загружаться на новых серверах.

  • Ликвидация поддержки хранения даты/времени и интервалов в виде чисел с плавающей точкой (Том Лейн)

    Параметр configure --disable-integer-datetimes был удалён. Использование для таких значений чисел с плавающей точкой не давало значимых преимуществ и не было вариантом по умолчанию, начиная с PostgreSQL 8.3.

  • Ликвидация поддержки сервером клиент-серверного протокола версии 1.0 (Том Лейн)

    Этот протокол не поддерживался клиентами со времён PostgreSQL 6.3.

  • Удаление модуля contrib/tsearch2 (Роберт Хаас)

    Этот модуль обеспечивал совместимость с версией полнотекстового поиска, которая поставлялась с серверами PostgreSQL до версии 8.3.

  • Ликвидация приложений командной строки createlang и droplang (Питер Эйзентраут)

    Они перешли в разряд устаревших в PostgreSQL 9.1. Вместо них можно непосредственно использовать команды CREATE EXTENSION и DROP EXTENSION.

  • Ликвидация поддержки вызовов функций версии 0 (Андрес Фройнд)

    Расширения, предоставляющие функции, реализованные на C, теперь должны использовать соглашение о вызовах версии 1. Версия 0 считалась устаревшей с 2001 года.

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

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

E.2.3.1. Сервер

E.2.3.1.1. Параллельное выполнение запросов
  • Поддержка параллельного сканирования индексов типа B-дерево (Рахила Сьед, Амит Капила, Роберт Хаас, Рафия Сабих)

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

  • Поддержка параллельного сканирования кучи по битовой карте (Дилип Кумар)

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

  • Реализована возможность выполнения соединения слиянием в параллельном режиме (Дилип Кумар)

  • Реализована возможность выполнения несвязанных запросов в параллельном режиме (Амит Капила)

  • Улучшение возможности параллельных процессов возвращать ранее отсортированные данные (Рушаб Латиа)

  • Расширение использования параллельных запросов в функциях процедурных языков (Роберт Хаас, Рафия Сабих)

  • Добавление серверного параметра max_parallel_workers для ограничения числа рабочих процессов, которые могут использоваться для распараллеливания запросов (Жульен Рухо)

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

E.2.3.1.2. Индексы
  • Добавление регистрации в журнале предзаписи операций с хеш-индексами (Амит Капила)

    В результате хеш-индексы становятся отказоустойчивыми и пригодными к репликации. Прежнее предостережение относительно их использование удалено.

  • Улучшение производительности хеш-индекса (Амит Капила, Митхун Ки, Ашутош Шарма)

  • Добавление поддержки индексов SP-GiST для типов данных INET и CIDR (Эмре Хасегели)

  • Добавление параметра для включения более активного вычисления сводных данных индекса BRIN (Альваро Эррера)

    Новый параметр CREATE INDEX позволяет автоматически обновлять сводную запись для предыдущей зоны страниц BRIN при создании новой зоны.

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

    Новая SQL-функция brin_summarize_range() обновляет сводные записи индекса BRIN для определённой зоны, а brin_desummarize_range() удаляет их. Это полезно для обновления данных зоны, которая стала меньше в результате действия команд UPDATE и DELETE.

  • Более точный расчёт выгоды от применения сканирования по индексу BRIN (Дэвид Роули, Эмре Хасегели)

  • Ускорение операций добавления и изменения записей в GiST благодаря более эффективному использованию пространства индекса (Андрей Бородин)

  • Минимизация блокировок страниц при очистке индексов GIN (Андрей Бородин)

E.2.3.1.3. Блокировки
  • Сокращение блокировок, необходимых для изменения параметров таблиц (Саймон Риггс, Фабрицио де Ройес Мелло)

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

  • Реализация регулировки пределов для повышения уровня предикатных блокировок (Дагфинн Ильмари Маннсакер)

    Повышением уровня блокировок теперь можно управлять с помощью двух новых параметров сервера, max_pred_locks_per_relation и max_pred_locks_per_page.

E.2.3.1.4. Оптимизатор
  • Добавление статистики по нескольким столбцам, позволяющей вычислять коэффициент корреляции и число различных значений (Томаш Вондра, Дэвид Роули, Альваро Эррера)

    Появились новые команды: CREATE STATISTICS, ALTER STATISTICS и DROP STATISTICS. Это полезно для оценки использования памяти запросом и для консолидации статистики по отдельным столбцам.

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

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

E.2.3.1.5. Общая производительность
  • Ускорение агрегатных функций, которые вычисляют сумму с накоплением, используя арифметику типа numeric, включая некоторые вариации SUM(), AVG() и STDDEV() (Хейкки Линнакангас)

  • Увеличение скорости преобразований кодировок символов с использованием цифровых деревьев (Кётаро Хоригути, Хейкки Линнакангас)

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

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

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

  • Использование гарантий уникальности для оптимизации определённых типов соединений (Дэвид Роули)

  • Ускорение сортировки типа данных macaddr (Брандур Лич)

  • Сокращение издержек на отслеживание статистики в сеансах, когда задействуются тысячи отношений (Александр Алексеев)

E.2.3.1.6. Мониторинг
  • Возможность явного управления отображением командой EXPLAIN времени планирования и выполнения (Ашутош Бапат)

    По умолчанию время планирования и выполнения выводится командой EXPLAIN ANALYZE и не выводится в других случаях. Явно управлять этим позволяет новый параметр SUMMARY команды EXPLAIN.

  • Добавлены новые стандартные роли для мониторинга (Дейв Пейдж)

    Новые роли pg_monitor, pg_read_all_settings, pg_read_all_stats и pg_stat_scan_tables позволяют упростить конфигурацию разрешений.

  • Исправление передачи информации сборщику статистики во время REFRESH MATERIALIZED VIEW (Джим Млодженски)

E.2.3.1.6.1. Ведение журнала
  • Изменение префикса log_line_prefix, чтобы по умолчанию все строки журнала postmaster содержали текущее время (с миллисекундами) и идентификатор процесса (Кристоф Берг)

    Ранее префикс по умолчанию был пустым.

  • Добавление функций для получения содержимого каталогов журнала сообщений и WAL (Дейв Пейдж)

    Новые функции называются соответственно pg_ls_logdir() и pg_ls_waldir() и могут выполняться не только суперпользователями (при наличии достаточных разрешений).

  • Добавление функции pg_current_logfile() для чтения имён текущих файлов, в которые сборщик сообщений выводит потоки stderr и csvlog (Жиль Даролд)

  • Вывод в журнал сервера адреса и номера порта для каждого принимающего соединения сокета при запуске postmaster (Том Лейн)

    Также добавление в сообщение об ошибке привязки к определённому сокету адреса этого сокета.

  • Устранение лишних сообщений о запуске и остановке подпроцессов запускающего процесса (Том Лейн)

    Теперь уровень этих сообщений понижен до DEBUG1.

  • Уменьшение уровня важности сообщений для уровней отладки, контролируемых параметром log_min_messages (Роберт Хаас)

    Это затрагивает также сообщения отладочных уровней client_min_messages.

E.2.3.1.6.2. Представление pg_stat_activity
  • Добавление в pg_stat_activity информации о состоянии низкоуровневых ожиданий (Мишель Пакье, Роберт Хаас)

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

  • Отображение в pg_stat_activity вспомогательных и фоновых рабочих процессов, а также процессов-передатчиков WAL (Кунтал Гхош, Мишель Пакье)

    Это упрощает мониторинг. Тип процесса обозначается в новом столбце backend_type.

  • В pg_stat_activity реализовано отображение SQL-запросов, выполняемых параллельными исполнителями (Рафия Сабих)

  • Переименование в pg_stat_activity.wait_event_type значений LWLockTranche и LWLockNamed в LWLock (Роберт Хаас)

    Это делает вывод более согласованным.

E.2.3.1.7. Аутентификация
  • Добавление поддержки SCRAM-SHA-256 для проверки и хранения паролей (Мишель Пакье, Хейкки Линнакангас)

    Это обеспечивает лучшую безопасность по сравнению с существующим методом md5.

  • Изменение типа серверного параметра password_encryption с boolean на enum (Мишель Пакье)

    Это потребовалось для поддержки различных вариантов хеширования паролей.

  • Добавление представления pg_hba_file_rules для просмотра содержимого pg_hba.conf (Харибабу Комми)

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

  • Поддержка нескольких серверов RADIUS (Магнус Хагандер)

    Все связанные с RADIUS параметры теперь стали множественными и принимают список серверов через запятую.

E.2.3.1.8. Конфигурация сервера
  • Возможность обновления конфигурации SSL при перезагрузке конфигурации (Андреас Карлссон, Том Лейн)

    Это позволяет переконфигурировать SSL без перезапуска сервера, используя pg_ctl reload, SELECT pg_reload_conf() или отправив сигнал SIGHUP. Однако, перезагрузка конфигурации SSL не сработает, если для использования SSL-ключа сервера требуется пароль, так как никакой возможности запросить его нет. В этом случае главный процесс (postmaster) продолжит использовать изначальную конфигурацию, пока не будет перезапущен.

  • Устранение практического предела для максимального значения bgwriter_lru_maxpages (Джим Нэсби)

E.2.3.1.9. Надёжность
  • После создания или удаления файлов следует выполнять fsync для каталога их содержащего (Мишель Пакье)

    Это сокращает риск потери данных при отключении питания.

  • Предотвращение ненужных контрольных точек и архивации WAL в простаивающих системах (Мишель Пакье)

  • Добавление серверного параметра wal_consistency_checking для внесения в WAL информации, позволяющей проверять целостность на ведомом сервере (Кунтал Гхош, Роберт Хаас)

    В случае выявления любого нарушения при проверке целостности на ведомом сервере выдаётся критическая ошибка.

  • Увеличение максимально допустимого размера сегмента WAL до одного гигабайта (Бина Емерсон)

    Увеличивая размер сегментов WAL, можно сократить частоту вызова archive_command и уменьшить число файлов WAL.

E.2.3.2. Репликация и восстановление

  • Реализация возможности логически реплицировать таблицы на подчинённые серверы (Петр Желинек)

    Логическая репликация даёт большую гибкость, чем физическая; в том числе позволяет организовывать репликацию между разными основными версиями PostgreSQL, а также избирательную репликацию.

  • Возможность ожидания подтверждения фиксации от ведомых серверов вне зависимости от их порядка в списке synchronous_standby_names (Масахико Савада)

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

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

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

  • По умолчанию репликация разрешается для локальных подключений в pg_hba.conf (Мишель Пакье)

    Ранее строки для подключений репликации в pg_hba.conf по умолчанию были закомментированы. Это особенно полезно для pg_basebackup.

  • Добавление в pg_stat_replication столбцов с информацией о задержках репликации (Томас Мунро)

    Новые столбцы называются write_lag, flush_lag и replay_lag.

  • Возможность указания точки остановки восстановления по LSN (последовательному номеру в журнале) в recovery.conf (Мишель Пакье)

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

  • Предоставление пользователям возможности отключить в функции pg_stop_backup() ожидание архивации всех файлов WAL (Дэвид Стил)

    Этим поведением управляет необязательный второй аргумент функции pg_stop_backup().

  • Возможность создания временных слотов репликации (Петр Желинек)

    Временные слоты автоматически удаляются при завершении сеанса или при ошибке.

  • Увеличение производительности воспроизведения в режиме горячего резерва благодаря оптимизации обработки исключительных блокировок (Саймон Риггс, Дэвид Роули)

  • Ускорение восстановления при двухфазной фиксации (Стас Кельвич, Никхил Сонтакке, Мишель Пакье)

E.2.3.3. Запросы

  • Добавление функции XMLTABLE, преобразующей данные в формате XML в набор табличных строк (Павел Стехуле, Альваро Эррера)

  • Исправление обработки в регулярных выражениях классов символов для символов с большими кодами, в частности, для символов Unicode больше U+7FF (Том Лейн)

    Ранее такие символы никогда не воспринимались как принадлежащие классам, зависящим от локали, например [[:alpha:]].

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

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

    Этот синтаксис поддерживает секционирование по спискам и по диапазонам.

  • Добавление для триггеров AFTER переходных таблиц, содержащих изменённые строки (Кевин Гриттнер, Томас Мунро)

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

  • Реализация ограничительных политик защиты на уровне строк (Стивен Фрост)

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

  • При создании ограничения внешнего ключа разрешение REFERENCES должно требоваться только для целевой таблицы (Том Лейн)

    Ранее также требовалось разрешение REFERENCES в таблице внешнего ключа. Это требование было реализовано из-за недопонимания SQL-стандарта. Так как для создания в таблице ограничения внешнего ключа (или подобного) требуются иметь права владельца этой таблицы, дополнительное требование разрешения REFERENCES кажется довольно бессмысленным.

  • Реализация прав по умолчанию для схем (Матеус Оливейра)

    Эти права задаются командой ALTER DEFAULT PRIVILEGES.

  • Добавление команды CREATE SEQUENCE AS для создания последовательностей определённого целочисленного типа данных (Питер Эйзентраут)

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

  • Поддержка команды COPY представление FROM источник для представлений с триггерами INSTEAD INSERT (Харибабу Комми)

    Триггеры получают строки данных, которые читает команда COPY.

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

    Например, теперь допускается указание DROP FUNCTION с именем функции без аргументов, если существует только одна функция с таким именем. Такое поведение требуется стандартом SQL.

  • Реализация возможности удалять несколько функций, операторов и агрегатов одной командой DROP (Питер Эйзентраут)

  • Поддержка предложения IF NOT EXISTS в командах CREATE SERVER, CREATE USER MAPPING и CREATE COLLATION (Анастасия Лубенникова, Питер Эйзентраут)

  • Добавление в вывод VACUUM VERBOSE количества пропущенных замороженных страниц и старейшего xmin (Масахико Савада, Саймон Риггс)

    Эта информация также включается в вывод с log_autovacuum_min_duration.

  • Ускорение удаления конечных пустых страниц кучи в процессе операции VACUUM (Клаудио Фрейре, Альваро Эррера)

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

  • Добавление поддержки полнотекстового поиска для типов JSON и JSONB (Дмитрий Долгов)

    С этими типами данных теперь могут использоваться функции ts_headline() и to_tsvector().

  • Добавление поддержки MAC-адресов EUI-64 в виде нового типа данных macaddr8 (Харибабу Комми)

    Этот тип дополняет ранее реализованную поддержку MAC-адресов EUI-48 (тип macaddr).

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

    Этот механизм подобен столбцам SERIAL, но соответствует стандарту SQL.

  • Реализация возможности переименовывать значения ENUM (Дагфинн Ильмари Маннсакер)

    Для этого используется синтаксис ALTER TYPE ... RENAME VALUE.

  • Исправление обращения с псевдотипами массивов (anyarray) как с массивами в функциях to_json() и to_jsonb() (Эндрю Дунстан)

    Ранее столбцы, объявленные как anyarray, (в частности, столбцы в представлении pg_stats) преобразовывались не в массивы, а в строки JSON.

  • Добавление операторов для умножения и деления значений money на значения int8 (Питер Эйзентраут)

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

  • Проверка переполнения в функции ввода типа money (Питер Эйзентраут)

E.2.3.6. Функции

  • Добавление упрощённой функции regexp_match() (Эмре Хасегели)

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

  • Новая версия оператора удаления для jsonb, принимающая массив ключей для удаления (Магнус Хагандер)

  • Реализация рекурсивной обработки объектов и массивов JSON в функции json_populate_record() и родственных ей (Никита Глухов)

    Благодаря этому изменению массивы JSON корректно преобразуются в поля-массивы в целевом типе SQL, а объекты JSON — в поля, представляющие собой составные типы. Ранее в таких случаях происходила ошибка при попытке передать строковое представление JSON-значения функциям array_in() и record_in(), так как синтаксис полученной строки не соответствовал ожидаемому этими функциями.

  • Добавление функции txid_current_if_assigned(), возвращающей идентификатор текущей транзакции или NULL, если транзакции не присвоен идентификатор (Крейг Рингер)

    Этим данная функция отличается от txid_current(), которая всегда возвращает идентификатор транзакции (назначая его, если он отсутствует). Данную функцию, в отличие от неё, можно выполнять на ведомых серверах.

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

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

  • Добавление функции make_date(), интерпретирующей отрицательные числа, как годы до нашей эры (Альваро Эррера)

  • Функции to_timestamp() и to_date() не должны принимать поля вне допустимых пределов (Артур Закиров)

    Например, ранее вызов to_date('2009-06-40','YYYY-MM-DD') выполнялся успешно и возвращалась дата 2009-07-10. Теперь с такими аргументами будет выдаваться ошибка.

E.2.3.7. Языки программирования на стороне сервера

  • Возможность вызывать функции cursor() и execute() в PL/Python как методы их аргумента — объекта plan (Питер Эйзентраут)

    Это позволяет придерживаться более объектно-ориентированного стиля программирования.

  • Реализована возможность получать значения оператора GET DIAGNOSTICS в PL/pgSQL в элементах массива (Том Лейн)

    Ранее синтаксическое ограничение не допускало использования в качестве целевой переменной элемента массива.

E.2.3.7.1. PL/Tcl
  • Возможность возвращать составные типы и наборы данных из функций PL/Tcl (Карл Лехенбауэр)

  • Добавление команды subtransaction в PL/Tcl (Виктор Вагнер)

    Это позволяет обработать ошибку в запросах PL/Tcl, не прерывая всю функцию.

  • Добавление серверных параметров pltcl.start_proc и pltclu.start_proc для указания функций инициализации, которые будут вызываться при запуске PL/Tcl (Том Лейн)

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

  • Реализована возможность указания нескольких адресов или имён серверов в строках подключения libpq и в строках URI (Роберт Хаас, Хейкки Линнакангас)

    Функции libpq будут подключаться к первому работоспособному узлу из этого списка.

  • В строках подключения libpq и URI добавлена возможность затребовать сервер для чтения/записи, то есть ведущий, а не ведомый сервер (Виктор Вагнер, Митхун Ки)

    Это полезно при указании нескольких имён узлов. Соответствующий параметр подключения libpq — target_session_attrs.

  • Реализована возможность задавать в параметрах подключения libpq имя файла паролей (Джулиан Маркворт)

    Ранее его можно было задать только в переменной окружения.

  • Добавлена функция PQencryptPasswordConn(), позволяющая создавать больше видов зашифрованных паролей на стороне клиента (Мишель Пакье, Хейкки Линнакангас)

    Ранее функцией PQencryptPassword() можно было создавать только пароли, зашифрованные MD5. Новая функция может также создавать и пароли, зашифрованные методом SCRAM-SHA-256.

  • Изменение версии препроцессора ecpg с 4.12 на 10 (Том Лейн)

    Впредь версия ecpg будет соответствовать номеру версии дистрибутива PostgreSQL.

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

E.2.3.9.1. psql
  • Добавлена поддержка условных ветвлений в psql (Кори Хинкер)

    В psql появились метакоманды \if, \elif, \else и \endif. Это полезно в первую очередь для скриптов.

  • Добавление в psql метакоманды \gx для выполнения запроса (запуска команды \g) в расширенном режиме (\x) (Кристоф Берг)

  • Расширение переменных psql внутри строк, заключённых в обратные апострофы (Том Лейн)

    Это особенно полезно в новых командах условного ветвления psql.

  • Недопущение установки некорректных значений для специальных переменных psql (Даниэль Верите, Том Лейн)

    Ранее, если какой-либо специальной переменной psql присваивалось некорректное значение, оно просто игнорировалось и применялось поведение по умолчанию. Теперь \set со специальной переменной выдаст ошибку при недопустимом новом значении. В виде особого исключения \set с пустым или без нового значения по-прежнему действует как присвоение переменной значения on; но теперь в переменной действительно оказывается это значение, а не пустая строка. Команда \unset со специальной переменной теперь действительно сбрасывает переменную так, что она получает значение по умолчанию, то есть то значение, которая она имела при запуске. В итоге управляющая переменная теперь всегда имеет отображаемое значение, отражающее, что фактически делает psql.

  • Добавление переменных, показывающих версию сервера и psql (Фабьен Коэльо)

  • Добавление в команды \d (показать отношение) и \dD (показать домен) вывода правила сортировки, допустимости NULL и свойств по умолчанию в отдельных столбцах (Питер Эйзентраут)

    Ранее вся эта информация выводилась в одном столбце «Модификаторы».

  • Унификация поведения команд \d в случаях, когда запрошенный объект не найден (Даниэль Густафсон)

    Теперь все они выводят сообщения об этом в stderr, а не в stdout, и текст сообщения стал более единообразным.

  • Усовершенствование дополнения табуляцией в psql (Джефф Джейнс, Иэн Барвик, Андреас Карлссон, Сероп Саркуни, Томас Мунро, Кевин Гриттнер. Дагфинн Ильмари Маннсакер)

E.2.3.9.2. pgbench
  • Добавление в pgbench параметра --log-prefix для установки префикса файла журнала (Масахико Савада)

  • Возможность разбивать метакоманды pgbench на несколько строк (Фабьен Коэльо)

    Теперь метакоманду можно продолжить на следующей строке, введя обратную косую черту перед переводом строки.

  • Устранение ограничения на положение параметра -M по отношению к другим параметрам командной строки (Том Лейн)

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

  • Добавление в pg_receivewal параметра -Z/--compress для включения сжатия (Мишель Пакье)

  • Добавление в pg_recvlogical параметра --endpos для указания конечной позиции (Крейг Рингер)

    Этот параметр дополняет существовавший ранее параметр --startpos.

  • Переименование параметров initdb --noclean и --nosync в --no-clean и --no-sync (Вик Фиринг, Питер Эйзентраут)

    Старое написание по-прежнему поддерживается.

  • В pg_restore реализована возможность исключать схемы (Михаэль Банк)

    Для этого добавлен новый ключ -N/--exclude-schema.

  • В pg_dump добавлен параметр --no-blobs (Гийом Леларж)

    Этот ключ отключает выгрузку больших объектов.

  • В pg_dumpall добавлен ключ --no-role-passwords для отказа от чтения паролей ролей (Робинс Таракан, Саймон Риггс)

    Это позволяет использовать pg_dumpall не только суперпользователям; без этого ключа pg_dumpall пытается прочитать пароли, а обычным пользователям это не разрешается.

  • Поддержка использования синхронных снимков при выгрузке данных с ведомого сервера (Петр Желинек)

  • Выполнение fsync() (синхронизации с ФС) для файлов, записываемых утилитами pg_dump и pg_dumpall (Мишель Пакье)

    Это позволяет более уверенно гарантировать, что выгруженные файлы безопасно сохранены на диске, до завершения работы программы. Это поведение можно отключить новым ключом --no-sync.

E.2.3.10.2. pg_basebackup
  • В pg_basebackup реализована возможность передавать журнал предзаписи в режиме tar (Магнус Хагандер)

    Содержимое WAL будет храниться в отдельном от основной копии файле tar.

  • Использование в pg_basebackup временных слотов репликации (Магнус Хагандер)

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

  • Более аккуратное выполнение синхронизации с ФС везде, где это требуется в pg_basebackup и pg_receivewal (Мишель Пакье)

  • Добавление в pg_basebackup ключа --no-sync для отключения синхронизации с ФС (Мишель Пакье)

  • Улучшение обработки в pg_basebackup пропускаемых каталогов (Дэвид Стил)

E.2.3.10.3. pg_ctl
  • Добавление параметра ожидания для операции повышения роли в pg_ctl (Питер Эйзентраут)

  • Добавление длинных ключей для работы pg_ctl с ожиданием (--wait) и без ожидания (--no-wait) (Вик Фиринг)

  • Добавление длинного ключа для параметров, которые pg_ctl передаёт серверу (--options) (Питер Эйзентраут)

  • В ожидании готовности сервера команда pg_ctl start --wait должна наблюдать за postmaster.pid, а не пытаться установить подключение (Том Лейн)

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

  • Уменьшение времени реакции pg_ctl в ожидании запуска/остановки процесса postmaster (Том Лейн)

    Теперь pg_ctl проверяет изменения состояния postmaster не один (как раньше), а десять раз в секунду.

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

    Теперь операции start и promote возвращают в таких случаях код состояния 1, а не 0. Операция stop делала это всегда.

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

  • Переход на нумерацию версий с двумя компонентами (Питер Эйзентраут, Том Лейн)

    Номера выпусков теперь состоят из двух частей (например, 10.1), а не из трёх (например, 9.6.3). Основные версии теперь будут увеличивать только первое число, а корректирующие выпуски — только второе. В названии ветвей выпусков будет включаться только одно число (например, 10 вместо 9.6). Это изменение произведено для того, чтобы пользователям было понятнее, что есть основная, а что — дополнительная версия PostgreSQL.

  • Улучшение поведения pgindent (Пётр Стефаняк, Том Лейн)

    Мы перешли на новую версию pg_bsd_indent, включающую последние усовершенствования из проекта FreeBSD. В результате устранено множество мелких ошибок, которые приводили к странным решениям относительно форматирования кода C. Одно из самых заметных изменений — строки в скобках (например, вызов функции, записанный в нескольких строках) теперь единообразно выравниваются по открывающей скобке, даже если в результате код будет выходить за правую границу.

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

    Библиотека ICU реализует версионирование, что позволяет выявлять изменения правил сортировки от версии к версии. Она подключается параметром configure --with-icu. По умолчанию для сортировки по-прежнему используется встроенная библиотека операционной системы.

  • Автоматическое добавление для всех функций PG_FUNCTION_INFO_V1 пометки DLLEXPORT в Windows (Лауренц Альбе)

    Если сторонний код использует объявления функций с характеристикой extern, они также должны иметь пометки DLLEXPORT в этих объявлениях.

  • Ликвидация ставших ненужными SPI-функций SPI_push(), SPI_pop(), SPI_push_conditional(), SPI_pop_conditional() и SPI_restore_connection() (Том Лейн)

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

    Побочным эффектом этого изменения стало то, что SPI_palloc() и родственные функции теперь требуют активного SPI-подключения; их действие не сводится к простому palloc(), если его нет. Предыдущее такое поведение оказалось не очень полезным и было чревато неожиданными утечками памяти.

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

  • Добавление механизма выделения памяти, подобного slab, для эффективного выделения памяти фиксированного размера (Томаш Вондра)

  • Использование семафоров POSIX вместо SysV в Linux и FreeBSD (Том Лейн)

    Это снимает некоторые присущие платформе лимиты на использование семафоров SysV.

  • Улучшение поддержки 64-битных атомарных операций (Андрес Фройнд)

  • Использование 64-битных атомарных операций на платформе ARM64 (Роман Шапошник)

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

    Если clock_gettime() недоступна, по-прежнему будет использоваться gettimeofday().

  • Добавление более надёжных генераторов случайных чисел для криптографического использования (Магнус Хагандер, Мишель Пакье, Хейкки Линнакангас)

    Если надёжный генератор случайных чисел не обнаруживается, процедура configure прервётся, если только дополнительно не передать ключ --disable-strong-random. Однако с этим ключом функции pgcrypto, которым требуется надёжный генератор случайных чисел, будут отключены.

  • В функции WaitLatchOrSocket() налажено ожидание подключения сокета в Windows (Андрес Фройнд)

  • Функции tupconvert.c более не преобразуют кортежи только для того, чтобы включить в них другой OID составного типа (Ашутош Бапат, Том Лейн)

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

  • Ликвидация портов SCO и Unixware (Том Лейн)

  • Переработка процесса сборки документации (Александр Лахин)

  • Использование XSLT для сборки документации PostgreSQL (Питер Эйзентраут)

    Ранее использовались программы Jade, DSSSL и JadeTex.

  • Сборка HTML-документации по умолчанию со стилями XSLT (Питер Эйзентраут)

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

  • Реализация в file_fdw возможности читать вывод программ, так же как и содержимое файлов (Кори Хинкер, Адам Гомаа)

  • В postgres_fdw реализована передача агрегатных функций на удалённый сервер, когда это возможно (Дживан Чок, Ашутош Бапат)

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

  • postgres_fdw может передавать соединения отношений на сторонний сервер в большем числе случаев (Дэвид Роули, Ашутош Бапат, Эцуро Фудзита)

  • Исправление поддержки столбцов OID в таблицах postgres_fdw (Эцуро Фудзита)

    Ранее в столбцах OID всегда возвращались нули.

  • Реализация в btree_gist и btree_gin возможности индексировать типы-перечисления (Эндрю Дунстан)

    Это позволяет использовать перечисления в ограничениях-исключениях.

  • Добавление в btree_gist поддержки индексации для типа данных UUID (Пол Юнгвирт)

  • Добавлено расширение amcheck, которое может проверять корректность индексов-B-деревьев (Питер Геохеган)

  • Отображение в pg_stat_statements игнорируемых констант как $N, а не как ? (Лукас Фиттл)

  • Улучшение в модуле cube обработки кубов с нулевой размерностью (Том Лейн)

    При этом также улучшена работа со значениями infinite и NaN.

  • Сокращение числа блокировок при обращении к представлению pg_buffercache (Иван Картышов)

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

  • Добавление в pgstattuple функции pgstathashindex() для просмотра статистики хеш-индексов (Ашутош Шарма)

  • Возможность использовать GRANT для управления доступом к функциям pgstattuple (Стивен Фрост)

    Это позволяет администраторам разрешать вызывать эти функции не только суперпользователям.

  • Сокращение числа блокировок в pgstattuple при просмотре хеш-индексов (Амит Капила)

  • Добавление в pageinspect функции page_checksum() для получения контрольной суммы страницы (Томаш Вондра)

  • Добавление в pageinspect функции bt_page_items(), которая выводит элементы страницы для переданного образа страницы (Томаш Вондра)

  • Добавление поддержки хеш-индексов в pageinspect (Джеспер Педерсен, Ашутош Шарма)

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

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

Адам Брайтвелл (Adam Brightwell)
Адам Брюссельбек (Adam Brusselback)
Адам Гомаа (Adam Gomaa)
Адам Сах (Adam Sah)
Адриан Клавер (Adrian Klaver)
Аидан Ван Дик (Aidan Van Dyk)
Александр Алексеев (Aleksander Alekseev)
Александр Коротков (Alexander Korotkov)
Александр Лахин (Alexander Lakhin)
Александр Сосна (Alexander Sosna)
Алексей Баштанов (Alexey Bashtanov)
Алексей Грищенко (Alexey Grishchenko)
Алексей Исайко (Alexey Isayko)
Альваро Эрнандес Тортоза (Álvaro Hernández Tortosa)
Альваро Эррера (Álvaro Herrera)
Амит Капила (Amit Kapila)
Амит Ланготе (Amit Langote)
Амит Хандекар (Amit Khandekar)
Амул Сул (Amul Sul)
Анастасия Лубенникова (Anastasia Lubennikova)
Андреас Джозеф Крог (Andreas Joseph Krogh)
Андреас Зельтенрейх (Andreas Seltenreich)
Андреас Карлссон (Andreas Karlsson)
Андреас Шербаум (Andreas Scherbaum)
Андрей Бородин (Andrey Borodin)
Андрей Лизенко (Andrey Lizenko)
Андрес Фройнд (Andres Freund)
Антонин Хоуска (Antonin Houska)
Антс Аасма (Ants Aasma)
Арсений Шер (Arseny Sher)
Артур Закиров (Artur Zakirov)
Арьен Нинхаус (Arjen Nienhuis)
Атсуши Торикоши (Atsushi Torikoshi)
Ашвин Агравал (Ashwin Agrawal)
Ашутош Бапат (Ashutosh Bapat)
Ашутош Шарма (Ashutosh Sharma)
Аюми Исии (Ayumi Ishii)
Бейзил Бурк (Basil Bourque)
Бен де Грааф (Ben de Graaff)
Бенедикт Грундман (Benedikt Grundmann)
Бернд Хелмле (Bernd Helmle)
Бина Емерсон (Beena Emerson)
Брандур Лич (Brandur Leach)
Брин Хаган (Breen Hagan)
Бруно Вольф III (Bruno Wolff III)
Брэд Дейонг (Brad DeJong)
Брюс Момджян (Bruce Momjian)
Вайшнави Прабакаран (Vaishnavi Prabakaran)
Венката Балажи Наготи (Venkata Balaji Nagothi)
Вик Фиринг (Vik Fearing)
Вики Вергара (Vicky Vergara)
Виктор Вагнер (Victor Wagner)
Винаяк Покале (Vinayak Pokale)
Вирен Неги (Viren Negi)
Виталий Буровой (Vitaly Burovoy)
Владимир Кунщиков (Vladimir Kunshchikov)
Владимир Русинов (Vladimir Rusinov)
Габриэль Бартолини (Gabriele Bartolini)
Габриэль Рот (Gabrielle Roth)
Гао Зенджи (Gao Zengqi)
Генри Болерт (Henry Boehlert)
Гердан Сантос (Gerdan Santos)
Гийом Леларж (Guillaume Lelarge)
Грег Аткинс (Greg Atkins)
Грег Бурек (Greg Burek)
Григорий Смолкин (Grigory Smolkin)
Грэхем Даттон (Graham Dutton)
Давид Феттер (David Fetter)
Дагфинн Ильмари Маннсакер (Dagfinn Ilmari Mannsåker)
Дайсукэ Хигути (Daisuke Higuchi)
Дамиан Кирога (Damian Quiroga)
Дан Мин Хыонг
Даниель Вестерман (Daniel Westermann)
Данило Глинский (Danylo Hlynskyi)
Даниэле Вараццо (Daniele Varrazzo)
Даниэль Верите (Daniel Vérité)
Даниэль Густафсон (Daniel Gustafsson)
Дарко Прелец (Darko Prelec)
Деврим Гюндюз (Devrim Gündüz)
Дейв Крамер (Dave Cramer)
Дейв Пейдж (Dave Page)
Денис Смирнов (Denis Smirnov)
Дениш Патель (Denish Patel)
Деннис Бьорклунд (Dennis Björklund)
Джанни Чиолли (Gianni Ciolli)
Джаред Уорд (Jarred Ward)
Джастин Муис (Justin Muise)
Джастин Призби (Justin Pryzby)
Джеймс Паркс (James Parks)
Джейсон Ли (Jason Li)
Джейсон О'Доннелл (Jason O'Donnell)
Джейсон Петерсен (Jason Petersen)
Джереми Финцель (Jeremy Finzel)
Джереми Шнайдер (Jeremy Schneider)
Джеспер Педерсен (Jesper Pedersen)
Джефф Девис (Jeff Davis)
Джефф Джейнс (Jeff Janes)
Джефф Дэфо (Jeff Dafoe)
Дживан Ладхе (Jeevan Ladhe)
Дживан Чок (Jeevan Chalke)
Джим Млодженски (Jim Mlodgenski)
Джим Нэсби (Jim Nasby)
Джинью Чжан (Jinyu Zhang)
Джо Конвей (Joe Conway)
Джон Беркус (Josh Berkus)
Джон Харви (John Harvey)
Джордан Гигов (Jordan Gigov)
Джош Сореф (Josh Soref)
Джоэл Джейкобсон (Joel Jacobson)
Джузеппе Брокколо (Giuseppe Broccolo)
Джулиан Маркворт (Julian Markwort)
Джун-сок Ян (Junseok Yang)
Дилип Кумар (Dilip Kumar)
Дилян Палаузов (Dilyan Palauzov)
Дин Рашид (Dean Rasheed)
Дмитрий Долгов (Dmitry Dolgov)
Дмитрий Иванов (Dimitry Ivanov)
Дмитрий Павлов (Dima Pavlov)
Дмитрий Сарафанников (Dmitriy Sarafannikov)
Дмитрий Федин (Dmitry Fedin)
Дон Моррисон (Don Morrison)
Дэвид Джонстон (David Johnston)
Дэвид Кристенсен (David Christensen)
Дэвид Роули (David Rowley)
Дэвид Рэйдер (David Rader)
Дэвид Стил (David Steele)
Дэн Вуд (Dan Wood)
Евгений Казаков (Eugene Kazakov)
Евгений Коньков (Eugen Konkov)
Егор Рогов (Egor Rogov)
Жиль Даролд (Gilles Darold)
Жульен Рухо (Julien Rouhaud)
И Вэнь Вон (Yi Wen Wong)
Иван Картышов (Ivan Kartyshov)
Игорь Корот (Igor Korot)
Ильдус Курбангалиев (Ildus Kurbangaliev)
Иэн Барвик (Ian Barwick)
Йелте Феннема (Jelte Fennema)
Йерун ван дер Хам (Jeroen van der Ham)
Йон Нельсон (Jon Nelson)
КайГай Кохэй (KaiGai Kohei)
Кайл Конрой (Kyle Conroy)
Карен Хаддлстон (Karen Huddleston)
Карл Лехенбауэр (Karl Lehenbauer)
Карл О. Пинц (Karl O. Pinc)
Каспер Жук (Kacper Zuk)
Каталин Якоб (Catalin Iacob)
Кевин Гриттнер (Kevin Grittner)
Кейт Фиске (Keith Fiske)
Ким Росе Карлсен (Kim Rose Carlsen)
Клаудио Фрейре (Claudio Freire)
Клинтон Адамс (Clinton Adams)
Конст Чжан (Const Zhang)
Константин Евтеев (Konstantin Evteev)
Константин Книжник (Konstantin Knizhnik)
Константин Пан (Constantin Pan)
Кори Хинкер (Corey Huinker)
Крейг Рингер (Craig Ringer)
Крис Бенди (Chris Bandy)
Крис Ричардс (Chris Richards)
Крис Рупрехт (Chris Ruprecht)
Кристиан Ульрих (Christian Ullrich)
Кристоф Берг (Christoph Berg)
Кунтал Гхош (Kuntal Ghosh)
Курт Карталтепе (Kurt Kartaltepe)
Куэль Чжо (QL Zhuo)
Кётаро Хоригути (Kyotaro Horiguchi)
Лауренц Альбе (Laurenz Albe)
Леонардо Чекки (Leonardo Cecchi)
Лукас Фиттл (Lukas Fittl)
Людовик Вожуа-Пепин (Ludovic Vaugeois-Pepin)
Магнус Хагандер (Magnus Hagander)
Майк Пальмиотто (Mike Palmiotto)
Майкл Дэй (Michael Day)
Максим Милютин (Maksim Milyutin)
Максим Соболев (Maksym Sobolyev)
Марек Чворен (Marek Cvoren)
Марк Дилгер (Mark Dilger)
Марк Кирквуд (Mark Kirkwood)
Марк Петер (Mark Pether)
Марк Расбах (Marc Rassbach)
Марк-Олаф Яшке (Marc-Olaf Jaschke)
Марко Тииккая (Marko Tiikkaja)
Маркос Кастедо (Marcos Castedo)
Маркус Винанд (Markus Winand)
Марллиус Рибейро (Marllius Ribeiro)
Марти Раудсепп (Marti Raudsepp)
Мартин Маркес (Martín Marqués)
Масахико Савада (Masahiko Sawada)
Матеус Оливейра (Matheus Oliveira)
Мерлин Монкьюр (Merlin Moncure)
Милош Урбанек (Milos Urbanek)
Митхун Ки (Mithun Cy)
Михаэль Банк (Michael Banck)
Михаэль Мескес (Michael Meskes)
Михаэль Овермайер (Michael Overmeyer)
Мишель Пакье (Michael Paquier)
Мойше Джейкобсон (Moshe Jacobson)
Муртуза Забуавала (Murtuza Zabuawala)
Мэтью Феньяк (Mathieu Fenniak)
Наоки Окано (Naoki Okano)
Натан Боссарт (Nathan Bossart)
Натан Вагнер (Nathan Wagner)
Неха Хатри (Neha Khatri)
Неха Шарма (Neha Sharma)
Никита Глухов (Nikita Glukhov)
Николай Никитин (Nikolay Nikitin)
Николай Шаплов (Nikolay Shaplov)
Николас Бачелли (Nicolas Baccelli)
Николас Гини (Nicolas Guini)
Николас Товен (Nicolas Thauvin)
Николаус Тиль (Nikolaus Thiel)
Никхил Сонтакке (Nikhil Sontakke)
Нил Андерсон (Neil Anderson)
Ной Миш (Noah Misch)
Нориёси Синода (Noriyoshi Shinoda)
Олаф Гавенда (Olaf Gawenda)
Олег Бартунов (Oleg Bartunov)
Оскари Сааренмаа (Oskari Saarenmaa)
Отар Шавадзе (Otar Shavadze)
Паван Деоласи (Pavan Deolasee)
Павел Голубь (Pavel Golub)
Павел Райскуп (Pavel Raiskup)
Павел Стехуле (Pavel Stehule)
Павел Ханак (Pavel Hanák)
Пареш Мор (Paresh More)
Петр Желинек (Petr Jelínek)
Питер Геохеган (Peter Geoghegan)
Питер Эйзентраут (Peter Eisentraut)
Пол Рамсей (Paul Ramsey)
Пол Юнгвирт (Paul Jungwirth)
Прабхат Саху (Prabhat Sahu)
Пьер-Эммануэль Андре (Pierre-Emmanuel André)
Пэн Сунь (Peng Sun)
Пётр Стефаняк (Piotr Stefaniak)
Рагнар Оухтерлони (Ragnar Ouchterlony)
Радек Слупик (Radek Slupik)
Раджкумар Рагхуванши (Rajkumar Raghuwanshi)
Райан Мерфи (Ryan Murphy)
Рафа де ла Торре (Rafa de la Torre)
Рафия Сабих (Rafia Sabih)
Рахила Сьед (Rahila Syed)
Регина Обе (Regina Obe)
Ричард Пистоль (Richard Pistole)
Роберт Хаас (Robert Haas)
Робинс Таракан (Robins Tharakan)
Род Тейлор (Rod Taylor)
Роман Шапошник (Roman Shaposhnik)
Рушаб Латиа (Rushabh Lathia)
Саймон Риггс (Simon Riggs)
Сандип Таккар (Sandeep Thakkar)
Свейн Свейнссон (Sveinn Sveinsson)
Свен Р. Кунце (Sven R. Kunze)
Себастьян Луке (Sebastian Luque)
Сергей Бурладян (Sergey Burladyan)
Сергей Копосов (Sergey Koposov)
Сероп Саркуни (Sehrope Sarkuni)
Симоне Готти (Simone Gotti)
Синтия Шан (Cynthia Shang)
Синъити Мацуда (Shinichi Matsuda)
Скотт Милликен (Scott Milliken)
Спенсер Томасон (Spencer Thomason)
Стас Кельвич (Stas Kelvich)
Степан Пестерников (Stepan Pesternikov)
Стив Рэндалл (Steve Randall)
Стив Сингер (Steve Singer)
Стивен Винфилд (Steven Winfield)
Стивен Фрост (Stephen Frost)
Стивен Фэклер (Steven Fackler)
Сурадж Хараге (Suraj Kharage)
Тайки Кондо (Taiki Kondo)
Такаюки Цунакава (Takayuki Tsunakawa)
Такэси Идэриха (Takeshi Ideriha)
Тахир Фахрутдинов (Tahir Fakhroutdinov)
Тацуо Исии (Tatsuo Ishii)
Тацуро Ямада (Tatsuro Yamada)
Тим Гудэйр (Tim Goodaire)
Тобиас Бусман (Tobias Bussmann)
Том Браун (Thom Brown)
Том Дунстан (Tom Dunstan)
Том Лейн (Tom Lane)
Тома ван Тилбург (Tom van Tilburg)
Томас Келлерер (Thomas Kellerer)
Томас Мунро (Thomas Munro)
Томаш Вондра (Tomas Vondra)
Томонари Кацумата (Tomonari Katsumata)
Тушар Ахуджа (Tushar Ahuja)
Фабрицио де Ройес Мелло (Fabrízio de Royes Mello)
Фабьен Коэльо (Fabien Coelho)
Фейке Стинберген (Feike Steenbergen)
Феликс Герзаге (Felix Gerzaguet)
Филип Йирсак (Filip Jirsák)
Филипп Бодуэн (Philippe Beaudoin)
Фудзии Масао (Fujii Masao)
Фёдор Сигаев (Teodor Sigaev)
Хайме Казанова (Jaime Casanova)
Ханс Бушман (Hans Buschmann)
Харибабу Комми (Haribabu Kommi)
Хейкки Линнакангас (Heikki Linnakangas)
Хуань Жуань (Huan Ruan)
Чепмен Флэк (Chapman Flack)
Чжоу Дигоал (Zhou Digoal)
Чжэнь Мин Ян (Zhen Ming Yang)
Чуаньтин Ван (Chuanting Wang)
Чхве Ду-Вон (Choi Doo-Won)
Чэнь Хуацзюнь (Chen Huajun)
Шо Като (Sho Kato)
Шон Фаррел (Sean Farrell)
Шэй Роджански (Shay Rojansky)
Эйдзи Сэки (Eiji Seki)
Эйлер Тавейра (Euler Taveira)
Эмил Иггланд (Emil Iggland)
Эмре Хасегели (Emre Hasegeli)
Энди Абелисто (Andy Abelisto)
Эндрю Вилрайт (Andrew Wheelwright)
Эндрю Гирт (Andrew Gierth)
Эндрю Дунстан (Andrew Dunstan)
Энрике Менесес (Enrique Meneses)
Эрвин Брандштеттер (Erwin Brandstetter)
Эрик Нордстром (Erik Nordström)
Эрик Рижкерс (Erik Rijkers)
Эцуро Фудзита (Etsuro Fujita)
Юго Нагата (Yugo Nagata)
Якоб Еггер (Jakob Egger)