这里有新鲜出炉的 SQL Server 教程,程序狗速度看过来!
SQL 是英文 Structured Query Language 的缩写,意思为结构化查询语言。SQL 语言的主要功能就是同各种数据库建立联系,进行沟通。按照 ANSI(美国国家标准协会) 的规定,SQL 被作为关系型数据库管理系统的标准语言。
SQL Server 即 Microsoft SQL Server 。
本文主要介绍了 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
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持 PHPERZ!
来源: http://www.phperz.com/article/17/0819/339127.html