Chapter 35. The Rule System
This chapter discusses the rule system in
PostgreSQL. Production rule systems
are conceptually simple, but there are many subtle points
involved in actually using them.
Some other database systems define active database rules, which
are usually stored procedures and triggers. In
PostgreSQL, these can be implemented
using functions and triggers as well.
The rule system (more precisely speaking, the query rewrite rule
system) is totally different from stored procedures and triggers.
It modifies queries to take rules into consideration, and then
passes the modified query to the query planner for planning and
execution. It is very powerful, and can be used for many things
such as query language procedures, views, and versions. The
theoretical foundations and the power of this rule system are
also discussed in On Rules, Procedures, Caching and Views in Database Systems
and A Unified Framework for Version Modeling Using Production Rules in a Database System.