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

51.4. PostgreSQL 规则系统 #

PostgreSQL 提供了一个强大的 规则系统,用于定义 视图 以及处理有歧义的 视图更新。最初,PostgreSQL 的规则系统由两种实现组成:

  • 第一种实现使用 行级 处理,并且深度实现于 执行器 内部。每当访问到单独一行时,规则系统就会被调用。这种实现在 1995 年被移除,当时 Berkeley Postgres 项目的最后一个官方发行版被转换成了 Postgres95

  • 规则系统的第二种实现是一种称为 查询重写 的技术。重写系统 是位于 解析器阶段规划器/优化器 之间的一个模块。这种技术至今仍在使用。

关于查询重写器,Chapter 39 中已有相当详细的讨论,因此这里没有必要再展开。我们只指出一点:重写器的输入和输出都是查询树,也就是说,树的表示形式以及语义细节层次都不会发生变化。重写可以被看作某种形式的宏展开。

提交更正

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