Глава 59. Написание обёртки сторонних данных

Содержание

59.1. Функции обёрток сторонних данных
59.2. Подпрограммы обёртки сторонних данных
59.2.1. Подпрограммы FDW для сканирования сторонних таблиц
59.2.2. Подпрограммы FDW для сканирования сторонних соединений
59.2.3. Подпрограммы FDW для планирования обработки после сканирования/соединения
59.2.4. Подпрограммы FDW для изменения данных в сторонних таблицах
59.2.5. Подпрограммы FDW для TRUNCATE
59.2.6. Подпрограммы FDW для блокировки строк
59.2.7. Подпрограммы FDW для EXPLAIN
59.2.8. Подпрограммы FDW для ANALYZE
59.2.9. Подпрограммы FDW для IMPORT FOREIGN SCHEMA
59.2.10. Подпрограммы FDW для параллельного выполнения
59.2.11. Подпрограммы FDW для асинхронного выполнения
59.2.12. Подпрограммы FDW для изменения параметризации путей
59.3. Вспомогательные функции для обёрток сторонних данных
59.4. Планирование запросов с обёртками сторонних данных
59.5. Блокировка строк в обёртках сторонних данных

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

Реализация обёрток сторонних данных, включённых в стандартный дистрибутив, может послужить хорошим примером при написании собственных обёрток. Её вы можете найти в подкаталоге contrib дерева исходного кода. Некоторые полезные детали также можно узнать на странице справки CREATE FOREIGN DATA WRAPPER.

Примечание

В стандарте SQL описан интерфейс для написания обёрток сторонних данных, но PostgreSQL не реализует его, так как это потребовало бы больших усилий, а данный стандартизированный API всё равно не получил широкого распространения.