Best Isolation Level to avoid deadlocks using an U

2020-07-30 03:25发布

i need execute un update statement over an sql server table, this table is used by another process at the same time. because that sometimes deadlocks ocurs. wich Isolation Level do you recomend to avoid or minimize this deadlocks?

4条回答
Lonely孤独者°
2楼-- · 2020-07-30 03:34
READ UNCOMMITTED

But that allows the process to read the data before a transaction has committed, what is known as a dirty read. Further Reading

You may prefer to turn on row versioning, the update creates a new version of the row and any other select statements use the old version until this one has committed. To do this turn on READ_COMMITTED_SNAPSHOT mode. There is more info here. There is an overhead involved maintaining the versions of the rows but it removes UPDATE/SELECT deadlocks.

查看更多
家丑人穷心不美
3楼-- · 2020-07-30 03:43

Use a cursor or a loop to update small numbers of rows in a batch, this avoids SQL Server escalting to a table lock.

查看更多
Juvenile、少年°
4楼-- · 2020-07-30 03:49

The suggestions to use READ UNCOMMITTED here are ok, but they really side-step the issue of why you're getting a deadlock in the first place. If you don't care about dirty reads then that's fine, but if you need to benefits of isolation (consistency, etc) then I recommend figuring out a proper locking strategy in your application.

I don't have the answer for you on that one - I've been working out some strategies on that myself. See the comments of this question for some discussion.

查看更多
欢心
5楼-- · 2020-07-30 03:51

Look into snapshot isolation - using this level of isolation is a good compromise between consistency and speed. I might be shot down in flames for saying this, however I believe that deadlocks are much more difficult to encounter at this isolation level.

Whether this is the right thing to do to get around your deadlock situation is another matter entirely.

查看更多
登录 后发表回答