F.30. pgrowlocks

pgrowlocksモジュールは、指定したテーブルにおける行ロックの情報を示す関数を提供します。

F.30.1. 概要

pgrowlocks(text) returns setof record

パラメータはテーブルの名前です。 結果はレコードの集合となり、各レコードはテーブル内のロックされた1行を示します。 出力列は表F-19の通りです。

表 F-19. pgrowlocksの出力列

名前説明
locked_rowtidロックされた行のタプルID(TID)
lock_typetext共有ロックの場合はShared、排他ロックの場合はExclusive
lockerxidロックを獲得したトランザクションのトランザクションID、もしマルチトランザクションの場合はmultixact ID
multibooleanロックをマルチトランザクションが獲得していた場合は真
xidsxid[]ロックを獲得しているトランザクションのトランザクションID(マルチトランザクションの場合は複数)
pidsinteger[]ロックを獲得しているバックエンドのプロセスID(マルチトランザクションの場合は複数)

pgrowlocksは対象テーブルに対してAccessShareLockを獲得し、ロック情報の収集のために1行ずつ行を読み取ります。 これは大規模テーブルにおいては高速とは言えません。 以下に注意してください:

  1. テーブル全体が他から排他ロックされている場合、pgrowlocksはブロックされます。

  2. pgrowlocksでは、自己矛盾のないスナップショットを生成することは保証されません。 その実行中に、新しい行ロックが獲得されることも、古いロックが解放されることもあり得ます。

pgrowlocksは、ロックされた行の内容は表示しません。 同時に行の内容を参照したい場合には、以下のようにして実現することができます:

SELECT * FROM accounts AS a, pgrowlocks('accounts') AS p
  WHERE p.locked_row = a.ctid;

しかし(PostgreSQL 8.3の時点では)こうした問い合わせが非常に非効率であることに注意してください。

F.30.2. サンプル出力

test=# SELECT * FROM pgrowlocks('t1');
 locked_row | lock_type | locker | multi |   xids    |     pids
------------+-----------+--------+-------+-----------+---------------
      (0,1) | Shared    |     19 | t     | {804,805} | {29066,29068}
      (0,2) | Shared    |     19 | t     | {804,805} | {29066,29068}
      (0,3) | Exclusive |    804 | f     | {804}     | {29066}
      (0,4) | Exclusive |    804 | f     | {804}     | {29066}
(4 rows)

F.30.3. 作者

Tatsuo Ishii