章 36. 扩展 SQL

目录
36.1. 扩展性如何工作
36.2. PostgreSQL类型系统
36.2.1. 基础类型
36.2.2. 组合类型
36.2.3.
36.2.4. 伪类型
36.2.5. 多态类型
36.3. 用户定义的函数
36.4. 查询语言(SQL)函数
36.4.1. SQL函数的参数
36.4.2. 基本类型上的SQL
36.4.3. 组合类型上的SQL函数
36.4.4. 带有输出参数的SQL函数
36.4.5. 带有可变数量参数的SQL函数
36.4.6. 带有参数默认值的SQL函数
36.4.7. SQL 函数作为表来源
36.4.8. 返回集合的SQL函数
36.4.9. 返回TABLESQL函数
36.4.10. 多态SQL函数
36.4.11. 带有排序规则的SQL函数
36.5. 函数重载
36.6. 函数易变性分类
36.7. 过程语言函数
36.8. 内部函数
36.9. C 语言函数
36.9.1. 动态载入
36.9.2. C 语言函数中的基本类型
36.9.3. 版本 0 调用约定
36.9.4. 版本 1 的调用约定
36.9.5. 编写代码
36.9.6. 编译和链接动态载入的函数
36.9.7. 组合类型参数
36.9.8. 返回行(组合类型)
36.9.9. 返回集合
36.9.10. 多态参数和返回类型
36.9.11. 转换函数
36.9.12. 共享内存和 LWLock
36.9.13. 把 C++ 用于可扩展性
36.10. 用户定义的聚集
36.10.1. 移动聚集模式
36.10.2. 多态和可变聚集
36.10.3. 有序集聚集
36.10.4. 部分聚集
36.10.5. 聚集的支持函数
36.11. 用户定义的类型
36.12. 用户定义的操作符
36.13. 操作符优化信息
36.13.1. COMMUTATOR
36.13.2. NEGATOR
36.13.3. RESTRICT
36.13.4. JOIN
36.13.5. HASHES
36.13.6. MERGES
36.14. 索引的接口扩展
36.14.1. 索引方法和操作符类
36.14.2. 索引方法策略
36.14.3. 索引方法支持例程
36.14.4. 一个例子
36.14.5. 操作符类和操作符族
36.14.6. 操作符类上的系统依赖
36.14.7. 排序操作符
36.14.8. 操作符类的特性
36.15. 打包相关对象到一个扩展中
36.15.1. 扩展文件
36.15.2. 扩展可再定位性
36.15.3. 扩展配置表
36.15.4. 扩展更新
36.15.5. 扩展实例
36.16. 扩展的构建基础设施

在下面的小节中,我们将讨论如何通过增加各种元素来扩展PostgreSQL SQL 查询语言: