Here's the sequence of events my hypothetical program makes...
- Open a connection to server.
- Run an UPDATE command.
- Go off and do something that might take a significant amount of time.
- Run another UPDATE that reverses the change in step 2.
- Close connection.
But oh-no! During step 3, the machine running this program literally exploded. Other machines querying the same database will now think that the exploded machine is still working and doing something.
What I'd like to do, is just as the connection is opened, but before any changes have been made, tell the server that should this connection close for whatever reason, to run some SQL. That way, I can be sure that if something goes wrong, the closing update will run.
(To pre-empt the answer, I'm not looking for table/record locks or transactions. I'm not doing resource claims here.)
Many thanks, billpg.