首页 新闻 会员 周边 捐助

sql更新update多条select信息时如何不脏读排他

0
悬赏园豆:30 [已解决问题] 解决于 2010-07-26 08:50

项目用的vs2003和sql2000

需要提取  num_product 不同条件的 数据信息同时在表中加上标示,

为了达到显示的时候,别的用户无法就把select的表数据给更新了一下标示,好方便提取

现在就是如何在更新读取避免重新更新和脏读

比如一次需要提取下面的几条语句的数据一起显示到前台

select top 10 Pro_id  from num_product where Adr_Code='jn'  AND  Pro_State=0  AND Sort_Type=1 AND TelType=0 AND pro_price='菏泽_普通号码' ORDER BY NEWID()

select top 2 Pro_id from num_product where Adr_Code='jn'  AND  Pro_State=0  AND Sort_Type=1 AND TelType=0 AND pro_price in(SELECT Step_Name FROM Num_Step WHERE Num_Step.ComType=6) ORDER BY NEWID()

如何做到 同时很多人读取,不产生冲突

                sql = "UPDATE Num_Product with(rowlock) SET Pro_State = 3,User_AdrCode = 'jn.01',Pro_UseCount = Pro_UseCount + 1,Agent_Code ='jn.01.01'  WHERE Pro_id IN(select top  10  Pro_id from num_product where Adr_Code='jn'  AND  Pro_State=0  AND Sort_Type=1 AND TelType=0 AND pro_price='菏泽_普通号码' ORDER BY NEWID())"

原来我是用这样更新的

哪位大哥 看看我这样写行吗

CREATE PROCEDURE [usp_AgentHand]
 @Adr_Code varchar(50), 
 @User_AdrCode varchar(50),
 @Pro_Ord varchar(50),
 @TelType varchar(10),
 @Agent_Code varchar(100),
 @ComEnd6 varchar(10),
 @ComHand4 varchar(10),
 @ComEnd4 varchar(10),
 @ComOther varchar(10)
AS
SET TRANSACTION ISOLATION LEVEL REPEATABLE READ
declare   @sql   varchar(4000)
begin transaction

 SET @sql='UPDATE Num_Product SET Pro_State=3,User_AdrCode='''+@User_AdrCode+''',Pro_UseCount=Pro_UseCount+1,Agent_Code ='''+@Agent_Code+''',Pro_Ord = '''+@Pro_Ord +''' WHERE Pro_id IN(select top '+ @ComOther+' Pro_id from num_product where Adr_Code='''+@Adr_Code+'''AND  Pro_State=0 AND Sort_Type=1 AND TelType='+@TelType+' AND pro_price=''菏泽_普通号码'' ORDER BY NEWID());'
 SET @sql=@sql+' UPDATE Num_Product SET Pro_State=3,User_AdrCode ='''+@User_AdrCode +''',Pro_UseCount = Pro_UseCount+1,Agent_Code ='''+@Agent_Code+''',Pro_Ord = '''+@Pro_Ord +''' WHERE Pro_id IN(select top '+@ComEnd6+' Pro_id from num_product where Adr_Code='''+@Adr_Code+''' AND Pro_State=0 AND Sort_Type=1 AND TelType='+@TelType+' AND pro_price IN(SELECT Step_Name FROM Num_Step WHERE ComType=6) ORDER BY NEWID());'
 SET @sql=@sql+' UPDATE Num_Product SET Pro_State=3,User_AdrCode='''+@User_AdrCode+''',Pro_UseCount=Pro_UseCount+1,Agent_Code ='''+@Agent_Code+''',Pro_Ord = '''+@Pro_Ord +''' WHERE Pro_id IN(select top '+ @ComEnd4+' Pro_id from num_product where Adr_Code='''+@Adr_Code+'''AND  Pro_State=0 AND Sort_Type=1 AND TelType='+@TelType+' AND pro_price IN(SELECT Step_Name FROM Num_Step WHERE Num_Step.ComType=4) ORDER BY NEWID());'
 SET @sql=@sql+' UPDATE Num_Product SET Pro_State=3,User_AdrCode='''+@User_AdrCode+''',Pro_UseCount=Pro_UseCount+1,Agent_Code ='''+@Agent_Code+''',Pro_Ord = '''+@Pro_Ord +''' WHERE Pro_id IN(select top '+ @ComHand4+' Pro_id from num_product where Adr_Code='''+@Adr_Code+'''AND  Pro_State=0 AND Sort_Type=1 AND TelType='+@TelType+' AND pro_price=''菏泽_普通号码'' AND left(Pro_Telenumber,7) like ''%4%'' ORDER BY NEWID());'
 exec(@sql)
 SELECT * FROM num_product WHERE Pro_State=3 AND User_AdrCode=@User_AdrCode AND Agent_Code =@Agent_Code AND TelType=@TelType AND Pro_Ord =@Pro_Ord
--print @sql
commit TRANSACTION
GO

 

 

问题补充: vs2003 + sql2000的程序1
没有想到好名字的主页 没有想到好名字 | 菜鸟二级 | 园豆:300
提问于:2010-07-20 15:18
< >
分享
最佳答案
0

在你的update前后加上事务锁定

收获园豆:15
changbluesky | 小虾三级 |园豆:854 | 2010-07-20 17:33
能帮忙写的详细一点吗 谢谢了
没有想到好名字 | 园豆:300 (菜鸟二级) | 2010-07-21 09:06
@躺着看板: ////有一点不明白: 为了达到显示的时候,别的用户无法就把select的表数据给更新了一下标示,好方便提取 ///// 就是在UI上面显示的时候,User不能够修改显示的数据?
changbluesky | 园豆:854 (小虾三级) | 2010-07-21 12:20
@我爱菊花: 他们不能修改显示数据
没有想到好名字 | 园豆:300 (菜鸟二级) | 2010-07-23 09:07
其他回答(1)
0

可以

select top 10 * from num_product where   Pro_State=0 for update

select top 6 * from num_product where   Pro_State=1 for update

你就可以在這個事務中做update操作,但是對其他的用戶

     1.允许普通select查询,不允许做for update查询。

     2. 不允许对表中任何记录做update操作;

     3. 允许insert操作;

     4. 不允许delete操作。

收获园豆:15
C.fly | 园豆:157 (初学一级) | 2010-07-20 17:47
能帮忙详细指点一下吗 谢谢
支持(0) 反对(0) 没有想到好名字 | 园豆:300 (菜鸟二级) | 2010-07-21 09:58
清除回答草稿
   您需要登录以后才能回答,未注册用户请先注册