Глава 35. Расширение SQL

Содержание

35.1. Как реализована расширяемость
35.2. Система типов Postgres Pro
35.2.1. Базовые типы
35.2.2. Типы-контейнеры
35.2.3. Домены
35.2.4. Псевдотипы
35.2.5. Полиморфные типы
35.3. Пользовательские функции
35.4. Пользовательские процедуры
35.5. Функции на языке запросов (SQL)
35.5.1. Аргументы SQL-функций
35.5.2. Функции SQL с базовыми типами
35.5.3. Функции SQL со сложными типами
35.5.4. Функции SQL с выходными параметрами
35.5.5. Функции SQL с переменным числом аргументов
35.5.6. Функции SQL со значениями аргументов по умолчанию
35.5.7. Функции SQL, порождающие таблицы
35.5.8. Функции SQL, возвращающие множества
35.5.9. Функции SQL, возвращающие таблицы (TABLE)
35.5.10. Полиморфные функции SQL
35.5.11. Функции SQL с правилами сортировки
35.6. Перегрузка функций
35.7. Категории изменчивости функций
35.8. Функции на процедурных языках
35.9. Внутренние функции
35.10. Функции на языке C
35.10.1. Динамическая загрузка
35.10.2. Базовые типы в функциях на языке C
35.10.3. Соглашение о вызовах версии 1
35.10.4. Написание кода
35.10.5. Компиляция и компоновка динамически загружаемых функций
35.10.6. Аргументы составного типа
35.10.7. Возврат строк (составных типов)
35.10.8. Возврат множеств
35.10.9. Полиморфные типы аргументов и результата
35.10.10. Разделяемая память и лёгкие блокировки
35.10.11. Использование C++ для расширяемости
35.11. Информация для оптимизации функций
35.12. Пользовательские агрегатные функции
35.12.1. Режим движущегося агрегата
35.12.2. Агрегатные функции с полиморфными и переменными аргументами
35.12.3. Сортирующие агрегатные функции
35.12.4. Частичное агрегирование
35.12.5. Вспомогательные функции для агрегатов
35.13. Пользовательские типы
35.14. Пользовательские операторы
35.15. Информация для оптимизации операторов
35.15.1. COMMUTATOR
35.15.2. NEGATOR
35.15.3. RESTRICT
35.15.4. JOIN
35.15.5. HASHES
35.15.6. MERGES
35.16. Интерфейсы расширений для индексов
35.16.1. Методы индексов и классы операторов
35.16.2. Стратегии методов индексов
35.16.3. Опорные процедуры метода индекса
35.16.4. Пример
35.16.5. Семейства и классы операторов
35.16.6. Системные зависимости от классов операторов
35.16.7. Операторы упорядочивания
35.16.8. Особенности классов операторов
35.17. Упаковывание связанных объектов в расширение
35.17.1. Файлы расширений
35.17.2. Перемещаемость расширений
35.17.3. Конфигурационные таблицы расширений
35.17.4. Обновление расширений
35.17.5. Установка расширений скриптами обновления
35.17.6. Замечания о безопасности расширений
35.17.7. Пример расширения
35.18. Инфраструктура сборки расширений

В следующих разделах мы обсудим, как в Postgres Pro можно расширять язык запросов SQL, добавляя собственные: