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

时间:2021-07-28  来源:php与数据库  阅读:

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))

 

 代码如下

settransactionisolationlevelSERIALIZABLE

BeginTran

 select1fromTablewith(UPDLOCK)where****--这里即算有索引支撑的情况下,加的也是范围锁RangeS-U,虽然能锁住,但并发性能也不佳。

 if @@ROWCOUNT = 0

 insertintoTable(****)values(****);

CommitTran

 

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

http://m.bbyears.com/jiaocheng/132553.html

推荐访问:sqlserver数据库
相关阅读 猜你喜欢
本类排行 本类最新