mirror of
https://github.com/postgres/postgres.git
synced 2025-05-05 09:19:17 +03:00
doc: clarify when row-level locks are released
They are released just like table-level locks. Also clean up wording. Reported-by: me@sillymon.ch Discussion: https://postgr.es/m/158074944048.1095.4309647363871637715@wrigleys.postgresql.org Backpatch-through: 9.5
This commit is contained in:
parent
ce5d82f2d0
commit
6e727a13cb
@ -1035,9 +1035,9 @@ ERROR: could not serialize access due to read/write dependencies among transact
|
||||
</tip>
|
||||
|
||||
<para>
|
||||
Once acquired, a lock is normally held till end of transaction. But if a
|
||||
Once acquired, a lock is normally held until the end of the transaction. But if a
|
||||
lock is acquired after establishing a savepoint, the lock is released
|
||||
immediately if the savepoint is rolled back to. This is consistent with
|
||||
immediately if the savepoint is rolled back. This is consistent with
|
||||
the principle that <command>ROLLBACK</> cancels all effects of the
|
||||
commands since the savepoint. The same holds for locks acquired within a
|
||||
<application>PL/pgSQL</> exception block: an error escape from the block
|
||||
@ -1174,7 +1174,10 @@ ERROR: could not serialize access due to read/write dependencies among transact
|
||||
conflicting locks on the same row, even in different subtransactions;
|
||||
but other than that, two transactions can never hold conflicting locks
|
||||
on the same row. Row-level locks do not affect data querying; they
|
||||
block only <emphasis>writers and lockers</emphasis> to the same row.
|
||||
block only <emphasis>writers and lockers</emphasis> to the same
|
||||
row. Row-level locks are released at transaction end or during
|
||||
savepoint rollback, just like table-level locks.
|
||||
|
||||
</para>
|
||||
|
||||
<variablelist>
|
||||
|
Loading…
x
Reference in New Issue
Block a user