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

Содержание

57.1. Функции обёрток сторонних данных
57.2. Подпрограммы обёртки сторонних данных
57.2.1. Подпрограммы FDW для сканирования сторонних таблиц
57.2.2. Подпрограммы FDW для сканирования сторонних соединений
57.2.3. Подпрограммы FDW для планирования обработки после сканирования/соединения
57.2.4. Подпрограммы FDW для изменения данных в сторонних таблицах
57.2.5. Подпрограммы FDW для TRUNCATE
57.2.6. Подпрограммы FDW для блокировки строк
57.2.7. Подпрограммы FDW для EXPLAIN
57.2.8. Подпрограммы FDW для ANALYZE
57.2.9. Подпрограммы FDW для IMPORT FOREIGN SCHEMA
57.2.10. Подпрограммы FDW для параллельного выполнения
57.2.11. Подпрограммы FDW для асинхронного выполнения
57.2.12. Подпрограммы FDW для изменения параметризации путей
57.3. Вспомогательные функции для обёрток сторонних данных
57.4. Планирование запросов с обёртками сторонних данных
57.5. Блокировка строк в обёртках сторонних данных

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

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

Примечание

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