ASP.NET 獨佔操作方法,防止使用者反覆提交造成資料庫處理失敗

來源:互聯網
上載者:User

 今天在執行一個預存程序中碰到了一個問題。系統裡,有一個預存程序,執行時間比較長,如果在網頁上使用者同時提交的數量比較多的話,裡面的事務就會執行失敗,造成處理錯誤。

實驗修改了這個事務的層級,從read uncomitted 改到serializable,但是都還是會出錯,分析原因,最有可能的是資料庫資源不夠,無法同時處理多個大規模的事務。既然資料庫這一塊不能解決問題,那麼,就從調用的程式入手,限定為完全順序執行,於是……解決問題。 現將方法貼出來,請各位指教。

環境 ASP.NET, 資料庫 SQLServer 2005

代碼很簡單,如下

 

Code
function RunProcedure()

{
  if (Application["lockobj"]==null) Application["lockobj"]=new Object();
  lock(Application["lockobj"])
  {
    // exec sp
    // 較長時間的等待, 10秒鐘左右
  }
  //其他處理
}

 

 

這樣保證不管有多少使用者同時進入,只能有一個使用者來運行這個預存程序,防止了錯誤,唯一的問題在於,使用者等待的時間會長一點……

請大家指教。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.