PostgreSQL 提供了一个强大的 规则系统,用于定义 视图 以及处理有歧义的 视图更新。最初,PostgreSQL 的规则系统由两种实现组成:
第一种实现使用 行级 处理,并且深度实现于 执行器 内部。每当访问到单独一行时,规则系统就会被调用。这种实现在 1995 年被移除,当时 Berkeley Postgres 项目的最后一个官方发行版被转换成了 Postgres95。
规则系统的第二种实现是一种称为 查询重写 的技术。重写系统 是位于 解析器阶段 与 规划器/优化器 之间的一个模块。这种技术至今仍在使用。
关于查询重写器,Chapter 39 中已有相当详细的讨论,因此这里没有必要再展开。我们只指出一点:重写器的输入和输出都是查询树,也就是说,树的表示形式以及语义细节层次都不会发生变化。重写可以被看作某种形式的宏展开。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。