记录表的锁定问题,行级锁,字段锁
有个项目,一直存在并发性问题,现在想改进下更新锁,
怎么样实现行级锁,字段锁,另外锁定状态允许脏读,只是锁更新.
功能简述:
****************************测试SQL**************************************************************************
if exists (select * from dbo.sysobjects where id = object_id(N'dbo.T_A') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table dbo.T_A
GO
CREATE TABLE dbo.T_A (
id int IDENTITY (1, 1) NOT NULL ,
Cname char(3) NOT NULL,
Vlabel varchar (20) NOT NULL ,
Amt int NOT NULL ,
PRIMARY KEY(id)
)
GO
if exists (select * from dbo.sysobjects where id = object_id(N'dbo.T_B') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table dbo.T_B
GO
CREATE TABLE dbo.T_B (
id int IDENTITY (1, 1) NOT NULL ,
Oname char(3) NOT NULL,
Vlabel varchar (20) NOT NULL ,
Amt int NOT NULL ,
YAmt int NOT NULL ,
PRIMARY KEY(id)
)
GO
Insert T_A(cname,vlabel,amt) values('AA','001',5000);
Insert T_A(cname,vlabel,amt) values('BB','002',2500);
Insert T_A(cname,vlabel,amt) values('AA','002',5000);
Insert T_A(cname,vlabel,amt) values('BB','001',4500);
go
Insert T_B(Oname,vlabel,amt,YAmt) values('T1','001',4500,0);
Insert T_B(Oname,vlabel,amt,YAmt) values('T2','001',5000,0);
Insert T_B(Oname,vlabel,amt,YAmt) values('T1','002',3500,0);
Insert T_B(Oname,vlabel,amt,YAmt) values('T2','002',4000,0);
go
select * from T_A
select * from T_B
****************************测试SQL**************************************************************************
表T_A中数据:
id cname vlabel amt
1 AA 001 5000
2 BB 002 2500
3 AA 002 5000
4 BB 001 4500
可看出上表中:
vlabel为001的amt共有,5000+4500=9500;
vlabel为002的amt共有,5000+2500=7500;
表T_B中数据
id Oname vlabel amt YAmt
1 T1 001 4500 0
2 T2 001 5000 0
3 T1 002 3500 0
4 T2 002 4000 0
可看出上表中:
vlabel为001的amt共有,5000+4500=9500;
vlabel为002的amt共有,5000+2500=7500;
生成过程:
由系统存储过程SP1,往T_A中插入数据,按规则对应给表T_B插入按Oname分配后的数据,
由于这个存储过程由多台,几十台机器调用,而表T_B中的Oname也可能为几十个,这样就存在严重的并发性问题,
现求最优解决方案。
1,怎么样控制SP1中更新,T_B中为行级锁,最好字段锁,因为Yamt是另外的过程来处理,可以同时由不同终端来更新;
2,SP1中更新表T_B中怎么知道哪些行被锁定,这样就可跳过不更新,避免并发等待。
已经提供测试表和数据的SQL,