diff --git a/doc/src/sgml/syntax.sgml b/doc/src/sgml/syntax.sgml index 4a02fab823f75874c91a8266d570f8eeffa904e6..d8cd5f18a28f322e4d63a4216de88d002c6fc753 100644 --- a/doc/src/sgml/syntax.sgml +++ b/doc/src/sgml/syntax.sgml @@ -1,5 +1,5 @@ <!-- -$Header: /cvsroot/pgsql/doc/src/sgml/syntax.sgml,v 1.32 2001/01/06 11:58:56 petere Exp $ +$Header: /cvsroot/pgsql/doc/src/sgml/syntax.sgml,v 1.33 2001/01/08 22:07:47 tgl Exp $ --> <chapter id="sql-syntax"> @@ -568,27 +568,33 @@ CAST ( '<replaceable>string</replaceable>' AS <replaceable>type</replaceable> ) <term>oid</term> <listitem> <para> - stands for the unique identifier of an instance which is added by - Postgres to all instances automatically. OIDs are not reused and are - 32-bit quantities. + The unique identifier (object ID) of a row. This is a serial number + that is added by Postgres to all rows automatically. OIDs are not + reused and are 32-bit quantities. </para> </listitem> </varlistentry> <varlistentry> - <term>xmin</term> + <term>tableoid</term> <listitem> <para> - The identity of the inserting transaction. + The OID of the table containing this row. This attribute is + particularly handy for queries that select from inheritance + hierarchies, since without it, it's difficult to tell which + individual table a row came from. The tableoid can be joined + against the OID attribute of pg_class to obtain the table name. </para> </listitem> </varlistentry> <varlistentry> - <term>xmax</term> + <term>xmin</term> <listitem> <para> - The identity of the deleting transaction. + The identity (transaction ID) of the inserting transaction for + this tuple. (Note: a tuple is an individual state of a row; + each UPDATE of a row creates a new tuple for the same logical row.) </para> </listitem> </varlistentry> @@ -597,7 +603,19 @@ CAST ( '<replaceable>string</replaceable>' AS <replaceable>type</replaceable> ) <term>cmin</term> <listitem> <para> - The command identifier within the inserting transaction. + The command identifier (starting at zero) within the inserting + transaction. + </para> + </listitem> + </varlistentry> + + <varlistentry> + <term>xmax</term> + <listitem> + <para> + The identity (transaction ID) of the deleting transaction, + or zero for an undeleted tuple. In practice, this is never nonzero + for a visible tuple. </para> </listitem> </varlistentry> @@ -606,7 +624,24 @@ CAST ( '<replaceable>string</replaceable>' AS <replaceable>type</replaceable> ) <term>cmax</term> <listitem> <para> - The command identifier within the deleting transaction. + The command identifier within the deleting transaction, or zero. + Again, this is never nonzero for a visible tuple. + </para> + </listitem> + </varlistentry> + + <varlistentry> + <term>ctid</term> + <listitem> + <para> + The tuple ID of the tuple within its table. This is a pair + (block number, tuple index within block) that identifies the + physical location of the tuple. Note that although the ctid + can be used to locate the tuple very quickly, a row's ctid + will change each time it is updated or moved by VACUUM. + Therefore ctid is useless as a long-term row identifier. + The OID, or even better a user-defined serial number, should + be used to identify logical rows. </para> </listitem> </varlistentry>