Приложение F. Дополнительно поставляемые модули

Содержание

F.1. adminpack
F.2. aqo
F.3. amcheck
F.4. auth_delay
F.5. auto_explain
F.6. bloom
F.7. btree_gin
F.8. btree_gist
F.9. chkpass
F.10. citext
F.11. spi
F.12. cube
F.13. dblink
F.14. dict_int
F.15. dict_xsyn
F.16. dump_stat
F.17. earthdistance
F.18. fasttrun
F.19. file_fdw
F.20. fulleq
F.21. fuzzystrmatch
F.22. hstore
F.23. Модули словарей Hunspell
F.24. intagg
F.25. intarray
F.26. isn
F.27. jsquery
F.28. lo
F.29. ltree
F.30. mchar
F.31. multimaster
F.32. online_analyze
F.33. pageinspect
F.34. passwordcheck
F.35. pg_buffercache
F.36. pgcrypto
F.37. pg_freespacemap
F.38. pg_hint_plan
F.39. pg_pathman
F.40. pg_prewarm
F.41. pgpro_scheduler
F.42. pg_query_state
F.43. pgrowlocks
F.44. pg_stat_statements
F.45. pgstattuple
F.46. pg_transfer
F.47. pg_trgm
F.48. pg_tsparser
F.49. pg_variables
F.50. pg_visibility
F.51. pg_wait_sampling
F.52. plantuner
F.53. postgres_fdw
F.54. referee
F.55. rum
F.56. seg
F.57. shared_ispell
F.58. sr_plan
F.59. sslinfo
F.60. tablefunc
F.61. tcn
F.62. test_decoding
F.63. tsearch2
F.64. tsm_system_rows
F.65. tsm_system_time
F.66. unaccent
F.67. uuid-ossp
F.68. xml2

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

В этом приложении описываются расширения и другие подключаемые серверные модули, включённые в contrib. В Приложении G описываются вспомогательные программы.

В Postgres Pro эти модули представлены в виде отдельного пакета, который может называться postgrespro-contrib-9.6. Точное имя пакета для вашей системы Linux вы можете узнать в Главе 17.

Многие модули предоставляют дополнительные пользовательские функции, операторы и типы. Чтобы использовать один из таких модулей, когда его исполняемый код установлен, вы должны зарегистрировать новые объекты SQL в СУБД. В Postgres Pro и PostgreSQL версии 9.1 и новее для этого нужно воспользоваться командой CREATE EXTENSION. В чистой базе данных вы можете просто выполнить:

CREATE EXTENSION имя_модуля;

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

Многие модули позволяют устанавливать свои объекты в схему по выбору. Для этого нужно добавить SCHEMA имя_схемы в команду CREATE EXTENSION. По умолчанию объекты устанавливаются в текущую схему для создаваемых объектов, которой по умолчанию становится public.

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

CREATE EXTENSION имя_модуля FROM unpackaged;

При этом объекты этого модуля версии до 9.1 будут упакованы в соответствующий объект расширения. После этого обновления расширения будут осуществляться командой ALTER EXTENSION. За дополнительными сведениями об обновлении расширении обратитесь к Разделу 36.15.

Однако некоторые из этих модулей не являются «расширениями» в этом смысле, а подключаются к серверу по-другому, например, через параметр конфигурации shared_preload_libraries. Подробнее об этом говорится в документации каждого модуля.