SQL Server死锁问题很值得我们去研究,下面就作了一个相关方面的测试,看看究竟什么时候会出现SQL Server死锁问题。
	SQL Server死锁测试 
--增设 帐户表_2 
CREATE TABLE 帐户表_2 
( 
帐号 CHAR(4), 
余额 INT 
) 
GO 
INSERT 帐户表_2 
SELECT 'C',100 
UNION ALL 
SELECT 'D',200
	--在第一个连接中执行以下语句 
BEGIN TRAN 
UPDATE 帐户表 SET 余额=3 WHERE 帐号='A' 
WAITFOR DELAY '00:00:10' 
UPDATE 帐户表_2 SET 余额=3 WHERE 帐号='C' 
COMMIT TRAN
	--在第二个连接中执行以下语句 
BEGIN TRAN 
UPDATE 帐户表_2 SET 余额=4 WHERE 帐号='C' 
WAITFOR DELAY '00:00:10' 
UPDATE 帐户表 SET 余额=4 WHERE 帐号='A' 
COMMIT TRAN
	--删除测试表 
DROP TABLE 帐户表,帐户表_2
	--同时执行,系统会检测出死锁,第一个连接的事务可能正常执行,SQL Server 终止第二个连接的事务(不涉及超时)。 
--如果没有出现死锁,则在其它事务释放锁之前,请求锁的事务被阻塞。 
--LOCK_TIMEOUT 设置允许应用程序设置语句等待阻塞资源的最长时间。
	4、更新数据时候允许进行插入 
5、插入数据时不允许更新\读取
