|
Posted by Chung Leong on 11/30/12 11:48
rich wrote:
> Someone gave me even a better idea. Use sessions in a table. Add to
> each user session a field for the Key field of each table in your
> database that is important. Example use the key field for a customer
> record. When you query the record for a change, write to that customer
> field in your seesion table the index of the record you are on.
> Whenever anyone opens that record, the ffirst thingyou do is query for
> the record number you are going to change and if it is found you cannot
> select the record because someone else has it open. Set your session
> max life time low enough so that a user can't sit on a record too long.
> This saves a person alot of work entering data only to be told someone
> else was using the record. I think this is a nice way of doing it.
That's a very bad idea. Whoever recommended it doesn't have a good
understanding of PHP's session garbage collection mechanism. There is
no timer somewhere that causes a session to become expired. Instead,
garbage collection *could* happen at the end of every request, with the
probability of it happening determined by session.gc_probability /
session.gc_divisor (in php.ini). The default is one in a hundred. If
site traffic is low, your record would be locked for many times the
session max life. Setting the probability to unity, on the other hand,
would be serious drag on performance/scalability.
There is nothing clever at all about the idea. It's just a locking
mechanism. You can easily implement a proper one without a custom
session handler.
[Back to original message]
|