diff --git a/doc/src/sgml/datatype.sgml b/doc/src/sgml/datatype.sgml index f7724f5e7045be5aac9291fbaa864959d238fcb5..e1e157ab379aafd776478cfd8558506bba45313d 100644 --- a/doc/src/sgml/datatype.sgml +++ b/doc/src/sgml/datatype.sgml @@ -1,4 +1,4 @@ -<!-- $PostgreSQL: pgsql/doc/src/sgml/datatype.sgml,v 1.212 2007/11/05 12:02:20 darcy Exp $ --> +<!-- $PostgreSQL: pgsql/doc/src/sgml/datatype.sgml,v 1.213 2007/11/05 14:51:08 momjian Exp $ --> <chapter id="datatype"> <title id="datatype-title">Data Types</title> @@ -3437,6 +3437,77 @@ SELECT to_tsquery('Fat:ab & Cats'); </sect1> + <sect1 id="datatype-txid-snapshot"> + <title>Transaction Snapshot Type</title> + + <indexterm zone="datatype-txid-snapshot"> + <primary>txid_snapshot</primary> + </indexterm> + + <para> + The data type <type>txid_snapshot</type> stores info about transaction ID + visibility at a particular moment in time. The components are + described in <xref linkend="datatype-txid-snapshot-parts">. + </para> + + <table id="datatype-txid-snapshot-parts"> + <title>Snapshot components</title> + <tgroup cols="2"> + <thead> + <row> + <entry>Name</entry> + <entry>Query Function</entry> + <entry>Description</entry> + </row> + </thead> + + <tbody> + + <row> + <entry><type>xmin</type></entry> + <entry>txid_snapshot_xmin()</entry> + <entry> + Earliest transaction ID that is still active. All earlier + transactions will either be committed and visible, or rolled + back and dead. + </entry> + </row> + + <row> + <entry><type>xmax</type></entry> + <entry>txid_snapshot_xmax()</entry> + <entry> + Next unassigned txid. All txids later than this one are + unassigned, and thus invisible. + </entry> + </row> + + <row> + <entry><type>xip_list</type></entry> + <entry>txid_snapshot_xip()</entry> + <entry> + Active txids at the time of snapshot. All of them are between + xmin and xmax. A txid that is <literal>xmin <= txid < + xmax</literal> and not in this list is visible. + </entry> + </row> + + </tbody> + </tgroup> + </table> + + <para> + Snapshot's textual representation is <literal>[xmin]:[xmax]:[xip_list]</literal> + for example <literal>10:20:10,14,15</literal> means + <literal>xmin=10 xmax=20 xip_list=10,14,15</literal>. + </para> + + <para> + Functions for getting and querying transaction ids and snapshots are + described in <xref linkend="functions-txid">. + </para> + </sect1> + <sect1 id="datatype-uuid"> <title><acronym>UUID</acronym> Type</title> diff --git a/doc/src/sgml/func.sgml b/doc/src/sgml/func.sgml index 34e9d56e65955b8fc3c544943d3bdbdc95fdc8ae..ad91d6d6af30e47f9005d206ff2b0287a2040ea9 100644 --- a/doc/src/sgml/func.sgml +++ b/doc/src/sgml/func.sgml @@ -1,4 +1,4 @@ -<!-- $PostgreSQL: pgsql/doc/src/sgml/func.sgml,v 1.406 2007/10/30 19:06:56 tgl Exp $ --> +<!-- $PostgreSQL: pgsql/doc/src/sgml/func.sgml,v 1.407 2007/11/05 14:51:08 momjian Exp $ --> <chapter id="functions"> <title>Functions and Operators</title> @@ -11490,6 +11490,11 @@ SELECT pg_type_is_visible('myschema.widget'::regtype); as well. </para> + </sect1> + + <sect1 id="functions-txid"> + <title>Transaction ID and Snapshot Functions</title> + <indexterm> <primary>txid_current</primary> </indexterm> @@ -11562,20 +11567,23 @@ SELECT pg_type_is_visible('myschema.widget'::regtype); </table> <para> - The internal transaction ID type (<type>xid</>) is 32 bits wide and so - it wraps around every 4 billion transactions. However, these functions - export a 64-bit format that is extended with an <quote>epoch</> counter - so that it will not wrap around for the life of an installation. + The internal transaction ID type (<type>xid</>) is 32 bits wide and + so it wraps around every 4 billion transactions. However, these + functions export a 64-bit format that is extended with an + <quote>epoch</> counter so that it will not wrap around for the life + of an installation. The main use of these functions is to determine + which transactions were committed between two snapshots. </para> + </sect1> - <sect1 id="functions-admin"> - <title>System Administration Functions</title> + <sect1 id="functions-admin"> + <title>System Administration Functions</title> - <para> - <xref linkend="functions-admin-set-table"> shows the functions - available to query and alter run-time configuration parameters. - </para> + <para> + <xref linkend="functions-admin-set-table"> shows the functions + available to query and alter run-time configuration parameters. + </para> <table id="functions-admin-set-table"> <title>Configuration Settings Functions</title>