45fan.com - 路饭网

搜索: 您的位置主页 > 网络频道 > 阅读资讯:怎么样在Sql server中防止并发插入重复数据?

怎么样在Sql server中防止并发插入重复数据?

2017-06-30 08:03:23 来源:www.45fan.com 【

怎么样在Sql server中防止并发插入重复数据?

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

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


本文地址:http://www.45fan.com/a/question/89328.html
Tags: 插入 防止 SQLServer
编辑:路饭网
关于我们 | 联系我们 | 友情链接 | 网站地图 | Sitemap | App | 返回顶部