受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

Chapter 36. 扩展 SQL

Table of Contents

36.1. 可扩展性如何运作
36.2. PostgreSQL 类型系统
36.2.1. 基础类型
36.2.2. 容器类型
36.2.3. 域
36.2.4. 伪类型
36.2.5. 多态类型
36.3. 用户定义的函数
36.4. 用户定义的过程
36.5. 查询语言(SQL)函数
36.5.1. SQL函数的参数
36.5.2. 基本类型上的SQL函数
36.5.3. 复合类型上的SQL函数
36.5.4. 带有输出参数的SQL函数
36.5.5. SQL有输出参数的过程
36.5.6. 带有可变数量参数的SQL函数
36.5.7. 带有参数默认值的SQL函数
36.5.8. SQL 函数作为表来源
36.5.9. 返回集合的SQL函数
36.5.10. 返回TABLESQL函数
36.5.11. 多态SQL函数
36.5.12. 带有排序规则的SQL函数
36.6. 函数重载
36.7. 函数易变性分类
36.8. 过程语言函数
36.9. 内部函数
36.10. C 语言函数
36.10.1. 动态载入
36.10.2. C 语言函数中的基本类型
36.10.3. 版本 1 的调用约定
36.10.4. 编写代码
36.10.5. 编译和链接动态装载函数
36.10.6. 服务器 API 和 ABI 稳定性指南
36.10.7. 复合类型参数
36.10.8. 返回行(复合类型)
36.10.9. 返回集合
36.10.10. 多态参数和返回类型
36.10.11. 共享内存
36.10.12. LWLocks
36.10.13. 自定义等待事件
36.10.14. 注入点
36.10.15. 自定义累计统计
36.10.16. 把 C++ 用于可扩展性
36.11. 函数优化信息
36.12. 用户定义的聚合
36.12.1. 移动聚合模式
36.12.2. 多态和可变参数聚合
36.12.3. 有序集聚合
36.12.4. 部分聚合
36.12.5. 聚合的支持函数
36.13. 用户定义的类型
36.13.1. TOAST 注意事项
36.14. 用户定义的操作符
36.15. 操作符优化信息
36.15.1. COMMUTATOR
36.15.2. NEGATOR
36.15.3. RESTRICT
36.15.4. JOIN
36.15.5. HASHES
36.15.6. MERGES
36.16. 索引扩展接口
36.16.1. 索引方法和操作符类
36.16.2. 索引方法策略
36.16.3. 索引方法支持例程
36.16.4. 示例
36.16.5. 操作符类和操作符族
36.16.6. 系统对操作符类的依赖
36.16.7. 排序操作符
36.16.8. 操作符类的特殊特性
36.17. 将相关对象打包成扩展
36.17.1. 扩展文件
36.17.2. 扩展的可重定位性
36.17.3. 扩展配置表
36.17.4. 扩展更新
36.17.5. 使用更新脚本安装扩展
36.17.6. 扩展的安全注意事项
36.17.7. 扩展示例
36.18. 扩展构建基础设施

在接下来的各节中,我们将讨论如何通过增加以下内容来扩展 PostgreSQL SQL 查询语言:

36.1. 可扩展性如何运作 #

PostgreSQL 之所以具有可扩展性,是因为它的运作由目录驱动。如果你熟悉标准的关系数据库系统,就会知道它们会把数据库、表、列等信息存储在通常所说的系统目录中(有些系统称之为数据字典)。这些目录对用户来说看起来和普通表无异,但 DBMS 会在其中保存自己的内部记账信息。PostgreSQL 与标准关系数据库系统的一个关键区别在于,它在目录中存储了更多信息:不仅包括表和列的信息,还包括数据类型、函数、访问方法等信息。这些表可以由用户修改,而 PostgreSQL 又正是基于这些表运行的,这就意味着用户可以扩展 PostgreSQL。相比之下,传统数据库系统通常只能通过修改源代码中的硬编码过程,或装入由 DBMS 供应商专门编写的模块来扩展。

此外,PostgreSQL 服务器还可以通过动态加载将用户编写的代码纳入自身。也就是说,用户可以指定一个实现新类型或新函数的目标代码文件(例如共享库),而 PostgreSQL 会在需要时加载它。把用 SQL 编写的代码加入服务器就更简单了。这种能够即时修改自身行为的能力,使 PostgreSQL 特别适合用于新应用和新存储结构的快速原型设计。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。