-
Notifications
You must be signed in to change notification settings - Fork 145
Optimistic Concurrency
In some systems, it is important to check whether someone else has changed your data while you aren't looking.
For example:
- Beer = SELECT Beer WHERE ID = 1
- Beer = Beer.Remaining * 0.5
- Someone else drinks the whole beer while you aren't looking.
- UPDATE Beer SET Remaining=0.5 WHERE ID = 1
This would result in infinite quantities of beer (awesome!), but not realistic, so you have to check. It usually goes something like this:
- BEGIN TRANSACTION
- Beer = SELECT Beer WHERE ID = 1
- Beer = Beer.Remaining * 0.5
- Someone else drinks the whole beer while you aren't looking.
- UPDATE Beer SET Remaining=0.5 WHERE ID = 1 AND Beer.Remaining = @oldvalue
- IF @@ROWCOUNT <> 0 ROLLBACK AND RAISERROR 'CONCURRENCY CHECK'
If you want to do concurrency checking with Insight.Database, it's not that hard.
First, make your SQL raise an error when you detect a concurrency exception. By default, Insight.Database will look for the string 'CONCURRENCY CHECK' in your exception.
IF @@ROWCOUNT <> 0 BEGIN ROLLBACK; RAISERROR 'CONCURRENCY CHECK', 16, 1; END
Then, wrap your connection in an OptimisticConnection:
var c = new OptimisticConnection(new SqlConnection(connectionString));
When the connection gets an exception, it checks for the text 'CONCURRENCY CHECK' and throws an OptimisticConcurrencyException. You can catch it:
try
{
c.Execute("UpdateBeer", beer);
}
catch(OptimisticConcurrencyException ox)
{
// someone drank your beer
}
If you are using Insight.Database.Schema and Autoprocs, you can enable Optimistic checks with the Optimistic
flag:
-- AUTOPROC All,Optimistic tablename
If you want to raise the exceptions a different way, you can also derive your own class from OptimisticConnection and override IsConcurrencyException.
Transactions - BACK || NEXT- Output Parameters
- Home
- About
- Getting Started
- Connections
- Execute
- Getting Results
- Advanced Results & Mapping
- Insert/Update Considerations
- Data Types
- Write Even Less Code
- Performance & Speed
- Other Topics
- Supported Databases
- Working with the Code