Глава 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.2.2. Подпрограммы FDW для сканирования сторонних соединений
- 59.2.1. Подпрограммы FDW для сканирования сторонних таблиц
- 59.3. Вспомогательные функции для обёрток сторонних данных
- 59.4. Планирование запросов с обёртками сторонних данных
- 59.5. Блокировка строк в обёртках сторонних данных
- 59.4. Планирование запросов с обёртками сторонних данных
Все операции со сторонней таблицей производятся через созданную для неё обёртку сторонних данных, представляющую собой набор подпрограмм, которые вызывает ядро сервера. Обёртка сторонних данных отвечает за получение данных из удалённого источника данных и передачу их исполнителю запросов Postgres Pro. Чтобы поддерживалось изменение данных в сторонних таблицах, эту операцию также должна выполнять обёртка. В данной главе освещается написание обёртки сторонних данных.
Реализация обёрток сторонних данных, включённых в стандартный дистрибутив, может послужить хорошим примером при написании собственных обёрток. Её вы можете найти в подкаталоге contrib
дерева исходного кода. Некоторые полезные детали также можно узнать на странице справки CREATE FOREIGN DATA WRAPPER.
Примечание
В стандарте SQL описан интерфейс для написания обёрток сторонних данных, но Postgres Pro не реализует его, так как это потребовало бы больших усилий, а данный стандартизированный API всё равно не получил широкого распространения.