Reading table records in SQL temporarily locks them until the query finishes its execution and all the data is returned to the client. This locking may slow down the execution times of other competing queries on the same table. We had one particular query in one table that would normally take 10 - 12 seconds when executed alone. As soon as you had that same query competing with 35 other threads it would take anywhere between 60 to 120 seconds.
So, how to set the READ UNCOMMITTED transaction level in LINQ to SQL?
Not that complicated after all:
You have to create your custom Linq context that inherits the base one created by Visual Studio and then handle the StateChange event of the context's Connection. It is there when you set the READ UNCOMMITED isolation level.
That's really the chicken. The rest is just additional methods to support OpenConnection:
After this work, our query now takes the expected 10 - 12 seconds regardless of the number of competing queries that are running in the same table at the same time.
No comments:
Post a Comment