Check if row exist (server-side) when multiple user can edit table
Check if row exist (server-side) when multiple user can edit table
data:image/s3,"s3://crabby-images/82f75/82f75bdf4a0b6b4d033316dfc6acd21d83107df6" alt="Benoit87"
Hello
I am trying to catch an error when multiple users have loaded same table and edit it.
For example :
2 users have loaded the same table, one of them delete a row. Other one edit this deleted row and received this error :
SQLSTATE[23000]: [Microsoft][ODBC Driver 17 for SQL Server][SQL Server]Cannot insert explicit value for identity column in table 'h_ligne' when IDENTITY_INSERT is set to OFF.
How can i check if row exist server-side and catch this error / abort process when this error happen ?
Thanks for your help
Answers
You'd need to use validators to confirm that the row is still present and can be acted upon. A validator on the primary key field to check that the row is still there would be the way to do it.
Another option would be to use a socket to tell the second client that the row has been deleted, which is what we do with CloudTables.
Allan
I did that, it seem to works fine, what do you think about it ?
Looks good to me - nice one, and thanks for posting back.
The only thing I would say is that personally I would use
$editor->db()
to get the Editor database class (you can then use thereference()
method if you didn't want to use our abstraction layer).The reason I say that is that Editor operates in a transaction by default - so reusing the object will make the query happen inside the transaction. At the validation stage that probably isn't too important, so not a big thing, but worth being aware of.
Allan