ASP.NET 独占操作方法,防止用户反复提交造成数据库处理失败

针对ASP.NET应用中SQL Server 2005存储过程执行失败的情况,通过限制调用顺序而非调整数据库事务级别解决了高并发时的问题。

 今天在执行一个存储过程中碰到了一个问题。系统里,有一个存储过程,执行时间比较长,如果在网页上用户同时提交的数量比较多的话,里面的事务就会执行失败,造成处理错误。

试验修改了这个事务的级别,从read uncomitted 改到serializable,但是都还是会出错,分析原因,最有可能的是数据库资源不够,无法同时处理多个大规模的事务。既然数据库这一块不能解决问题,那么,就从调用的程序入手,限定为完全顺序执行,于是……解决问题。 现将方法贴出来,请各位指教。

环境 ASP.NET, 数据库 SQLServer 2005

代码很简单,如下

 

ContractedBlock.gifExpandedBlockStart.gifCode
function RunProcedure()

{
  
if (Application["lockobj"]==null) Application["lockobj"]=new Object();
  
lock(Application["lockobj"])
  {
    
// exec sp
    
// 较长时间的等待, 10秒钟左右
  }
  
//其他处理
}

 

 

这样保证不管有多少用户同时进入,只能有一个用户来运行这个存储过程,防止了错误,唯一的问题在于,用户等待的时间会长一点……

请大家指教。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值