SQLServer中防止并发插入重复数据的方法详解
更新时间:2017年03月19日 09:27:50 作者:万剑齐发
本文主要介绍了SQLServer中防止并发插入重复数据的方法,具有很好的参考价值。下面跟着小编一起来看下吧
SQLServer中防止并发插入重复数据,大致有以下几种方法:
1.使用Primary Key,Unique Key等在数据库层面让重复数据无法插入。
2.插入时使用条件
insert into Table(****) select **** where not exists(select 1 from Table where ****);
3.使用SERIALIZABLE隔离级别,并且使用updlock或者xlock锁提示(等效于在默认隔离级别下使用(updlock,holdlock)或(xlock,holdlock))
set transaction isolation level SERIALIZABLE Begin Tran select 1 from Table with(UPDLOCK) where **** --这里即算有索引支撑的情况下,加的也是范围锁RangeS-U,虽然能锁住,但并发性能也不佳。 if @@ROWCOUNT = 0 insert into Table (****) values(****); Commit Tran
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!
相关文章
通过使用正确的search arguments来提高SQL Server数据库的性能
今天通过本文给大家介绍在SQL Server上关于indexing的一个特定的性能问题,本文给大家介绍的非常详细,具有参考借鉴价值,感兴趣的朋友可以参考下2016-11-11
最新评论