狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

MSSQL數據庫查詢“超時時間已到……”的解決方案

admin
2012年3月2日 23:10 本文熱度 2947
問題描述
---------------------------------------------------------------------------------------------------
數據庫鏈接字符串:
Data Source=*.*.*.*;InitialCatalog=DatabaseName;Persist Security Info=True;UserID=****;Password=******
使用SqlHelper組件處理數據庫查詢業務,在MSSQL數據庫中進行大數據量查詢的時候,會經常出現“超時時間已到。在操作完成之前超時時間已過或服務器未響應。”的錯誤。

原因分析
---------------------------------------------------------------------------------------------------
1、當數據庫表中存在超大數據記錄,則在應用程序Command命令執行時,使用默認的數據庫鏈接超時時間(30秒)配置就容易出現以上超時錯誤;
2、在事務開始BeginTransaction()與事務結束transaction.Commit()中間用到了沒有啟動事務的過程,如其他查詢等,會提示此錯誤;
3、在web頁面上傳大批量文件時,也容易出現超時錯誤;

解決方案
---------------------------------------------------------------------------------------------------
1、可以在數據庫連接字符串中加入以下參數:

Connect Timeout=600;Enlist=true; Pooling=true; Max Pool Size=512; Min Pool Size=0;Connection Lifetime=600

2、如果數據量非常大,以上超時錯誤仍然存在,則可以在數據庫創建鏈接時自定義延長數據庫執行超時時間,并參考以下代碼段:

using (SqlCommand cmd = new SqlCommand())
{
    using (SqlConnection connection =new SqlConnection(dbConnStr))
    {
      connection.Open();

      cmd.Connection = connection;
      cmd.CommandTimeout = cmd.Connection.ConnectionTimeout;

      cmd.CommandText = sqlStr; //數據庫執行查詢語句,內容略
       object temp1 = cmd.ExecuteScalar();//同樣適用于其他數據庫操作

      connection.Close();
    }
}

3、對于web應用程序超時,可以在web.config中增加以下語句:
<system.web>
       <httpRuntime maxRequestLength="102400" executionTimeout="1800" />
</system.web>
httpRuntime:是配置asp.nethttp運行時設置,以確定如何處理對asp.net應用程序的請求;
executionTimeout:表示允許執行請求的最大時間限制,單位為秒;
maxRequestLength:指示 ASP.NET支持的最大文件上載大小,該限制可用于防止因用戶將大量文件傳遞到該服務器而導致的拒絕服務攻擊。指定的大小以 KB 為單位。默認值為4096 KB (4 MB);
~其他配置參考~
useFullyQualifiedRedirectUrl:表示指示客戶端重定向是否是完全限定的(采用"http://server/path" 格式,這是某些移動控件所必需的),或者指示是否代之以將相對重定向發送到客戶端。如果為True,則所有不是完全限定的重定向都將自動轉換為完全限定的格式。false 是默認選項;
minFreeThreads:表示指定允許執行新請求的自由線程的最小數目。ASP.NET為要求附加線程來完成其處理的請求而使指定數目的線程保持自由狀態。默認值為 8;
minLocalRequestFreeThreads:表示ASP.NET保持的允許執行新本地請求的自由線程的最小數目。該線程數目是為從本地主機傳入的請求而保留的,以防某些請求在其處理期間發出對本地主機的子請求。這避免了可能的因遞歸重新進入Web 服務器而導致的死鎖;
appRequestQueueLimit:表示ASP.NET將為應用程序排隊的請求的最大數目。當沒有足夠的自由線程來處理請求時,將對請求進行排隊。當隊列超出了該設置中指定的限制時,將通過“503- 服務器太忙”錯誤信息拒絕傳入的請求;
enableVersionHeader:表示指定ASP.NET 是否應輸出版本標頭。Microsoft Visual Studio 2005 使用該屬性來確定當前使用的ASP.NET 版本。對于生產環境,該屬性不是必需的,可以禁用。

該文章在 2012/3/2 23:10:35 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved