当前位置: 移动技术网 > IT编程>数据库>MSSQL > SQLServer中防止并发插入重复数据的方法详解

SQLServer中防止并发插入重复数据的方法详解

2017年12月08日  | 移动技术网IT编程  | 我要评论

江苏教育学院地址,金鸡湖灯会,心动电影网

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

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持移动技术网!

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网