Commit 42c6236f authored by Tom Lane's avatar Tom Lane

Fix documentation about joining pg_locks to other views.

The advice to join to pg_prepared_xacts via the transaction column was not
updated when the transaction column was replaced by virtualtransaction.
Since it's not quite obvious how to do that join, give an explicit example.
For consistency also give an example for the adjacent case of joining to
pg_stat_activity.  And link-ify the view references too, just because we
can.  Per bug #9840 from Alexey Bashtanov.

Michael Paquier and Tom Lane
parent 879808e5
...@@ -7871,16 +7871,27 @@ ...@@ -7871,16 +7871,27 @@
<para> <para>
The <structfield>pid</structfield> column can be joined to the The <structfield>pid</structfield> column can be joined to the
<structfield>pid</structfield> column of the <structfield>pid</structfield> column of the <link
<structname>pg_stat_activity</structname> view to get more linkend="pg-stat-activity-view"><structname>pg_stat_activity</structname></link>
information on the session holding or waiting to hold each lock. view to get more
information on the session holding or waiting to hold each lock,
for example
<programlisting>
SELECT * FROM pg_locks pl LEFT JOIN pg_stat_activity psa
ON pl.pid = psa.pid;
</programlisting>
Also, if you are using prepared transactions, the Also, if you are using prepared transactions, the
<structfield>transaction</> column can be joined to the <structfield>virtualtransaction</> column can be joined to the
<structfield>transaction</structfield> column of the <structfield>transaction</structfield> column of the <link
<structname>pg_prepared_xacts</structname> view to get more linkend="view-pg-prepared-xacts"><structname>pg_prepared_xacts</structname></link>
information on prepared transactions that hold locks. view to get more information on prepared transactions that hold locks.
(A prepared transaction can never be waiting for a lock, (A prepared transaction can never be waiting for a lock,
but it continues to hold the locks it acquired while running.) but it continues to hold the locks it acquired while running.)
For example:
<programlisting>
SELECT * FROM pg_locks pl LEFT JOIN pg_prepared_xacts ppx
ON pl.virtualtransaction = '-1/' || ppx.transaction;
</programlisting>
</para> </para>
<para> <para>
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment