SQLProvider
SQLProvider copied to clipboard
Any Optimistic Concurrency Control support (MS SQL Server)?
Description
I'm looking for a way to add Optimistic Concurrency Control in SQLProvider, based on TIMESTAMP columns (MSSQL). Similar to how it is done in Entity Framework.
Is there anything built-in? If not then a workaround or an extension?
Repro steps
-
Create context, read a record from a table with TIMESTAMP column.
-
Update some property of the record.
-
Hit the breakpoint to make debugger stop just before ctx.SubmitUpdates(). Run the code in debugger.
-
Concurrently update the record in MS SQL server (e.g. via SQL Management Studio) so record read in Step 1 becomes obsolete
-
Resume debugger and execute ctx.SubmitUpdates()
Expected behavior
A runtime error saying that record was updated concurrently, no changes in database.
Actual behavior
SubmitUpdates() writes changes to database, regardless whether timestamp is obsolete or not.
Known workarounds
Don't know any out of the box. A stored procedure can be written instead which is tedious.
Related information
- Used database: MSSQLSERVER
- Operating system: Windows 10
- .NET Core 2.1
There were something like this https://github.com/fsprojects/SQLProvider/pull/548
This could be achieved with one UPDATE query, if timestamp column added to "WHERE" clause / throw exception if @@ROWCOUNT = 0 after the update
My intuition was that recordToUpdate.OnConflict <- OnConflict.Throw will do the trick but I was wrong.