>>>>> "Tom" == Tom Lane <[EMAIL PROTECTED]> writes:
Tom> "Jenny -" <[EMAIL PROTECTED]> writes:
>> Iam trying to acquire rowlevel locks in postgresql. I try doing
>> this: 'select * from students where name='Larry' for update;
>> But by looking at the holding array of proclock , I've noticed
>> that by doing this only AccessShareLock gets acquired which is
>> a table level lock.
Tom> Row-level locks are not recorded in proclock --- they are
Tom> implemented by marking the individual tuple on-disk. If we
Tom> tried to record them in shared memory, it'd be very easy to
Tom> run out of shared memory, because you could be holding row
Tom> locks on a large number of tuples.
Of course, other database systems do this without too much hassle
.. including relying on lock escalation (move up to page/table level
locks) when the number of locks grow too large.
Does pgsql only record X locks on the individual tuples on-disk or
does it do so for S locks as well ?
Not that I dislike the idea - Toby Lehman suggested this in his
Ph.D. thesis in the mid-eighties for main-memory databases (where you
don't take the write penalty).
--
Pip-pip
Sailesh
http://www.cs.berkeley.edu/~sailesh
---------------------------(end of broadcast)---------------------------
TIP 4: Don't 'kill -9' the postmaster