summaryrefslogtreecommitdiff
path: root/doc/src/sgml/ref/create_rule.sgml
diff options
context:
space:
mode:
authorBruce Momjian <bruce@momjian.us>2004-03-04 14:32:12 +0000
committerBruce Momjian <bruce@momjian.us>2004-03-04 14:32:12 +0000
commitf503b6a8211f2815a55ab998f50214a86fe73032 (patch)
tree8085f2a131ae7344e5e79352b19889b765245931 /doc/src/sgml/ref/create_rule.sgml
parentf3c6d592d21b81e60f6a2358c68bc527d49302f7 (diff)
Better document INSTEAD behavior for rules.
Diffstat (limited to 'doc/src/sgml/ref/create_rule.sgml')
-rw-r--r--doc/src/sgml/ref/create_rule.sgml31
1 files changed, 21 insertions, 10 deletions
diff --git a/doc/src/sgml/ref/create_rule.sgml b/doc/src/sgml/ref/create_rule.sgml
index fbaa16cecdc..412ebcd66b6 100644
--- a/doc/src/sgml/ref/create_rule.sgml
+++ b/doc/src/sgml/ref/create_rule.sgml
@@ -1,5 +1,5 @@
<!--
-$PostgreSQL: pgsql/doc/src/sgml/ref/create_rule.sgml,v 1.42 2003/11/29 19:51:38 pgsql Exp $
+$PostgreSQL: pgsql/doc/src/sgml/ref/create_rule.sgml,v 1.43 2004/03/04 14:32:12 momjian Exp $
PostgreSQL documentation
-->
@@ -42,15 +42,15 @@ CREATE [ OR REPLACE ] RULE <replaceable class="parameter">name</replaceable> AS
define an alternate action to be performed on insertions, updates,
or deletions in database tables. Roughly speaking, a rule causes
additional commands to be executed when a given command on a given
- table is executed. Alternatively, a rule can replace a given
- command by another, or cause a command not to be executed at all.
- Rules are used to implement table views as well. It is important
- to realize that a rule is really a command transformation
- mechanism, or command macro. The transformation happens before the
- execution of the commands starts. If you actually want an
- operation that fires independently for each physical row, you
- probably want to use a trigger, not a rule. More information about
- the rules system is in <xref linkend="rules">.
+ table is executed. Alternatively, an <literal>INSTEAD</literal>
+ rule can replace a given command by another, or cause a command
+ not to be executed at all. Rules are used to implement table
+ views as well. It is important to realize that a rule is really
+ a command transformation mechanism, or command macro. The
+ transformation happens before the execution of the commands starts.
+ If you actually want an operation that fires independently for each
+ physical row, you probably want to use a trigger, not a rule.
+ More information about the rules system is in <xref linkend="rules">.
</para>
<para>
@@ -141,6 +141,17 @@ CREATE [ OR REPLACE ] RULE <replaceable class="parameter">name</replaceable> AS
</varlistentry>
<varlistentry>
+ <term><option>INSTEAD</option></term>
+ <listitem>
+ <para>
+ <literal>INSTEAD</literal> indicates that the commands should be
+ executed <emphasis>instead</> of the original command, not in
+ addition to the original command.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
<term><replaceable class="parameter">command</replaceable></term>
<listitem>
<para>