超碰人人人人人,亚洲AV午夜福利精品一区二区,亚洲欧美综合区丁香五月1区,日韩欧美亚洲系列

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

MSSQL數(shù)據(jù)庫查詢“超時(shí)時(shí)間已到……”的解決方案

admin
2012年3月2日 23:10 本文熱度 3503
問題描述
---------------------------------------------------------------------------------------------------
數(shù)據(jù)庫鏈接字符串:
Data Source=*.*.*.*;InitialCatalog=DatabaseName;Persist Security Info=True;UserID=****;Password=******
使用SqlHelper組件處理數(shù)據(jù)庫查詢業(yè)務(wù),在MSSQL數(shù)據(jù)庫中進(jìn)行大數(shù)據(jù)量查詢的時(shí)候,會(huì)經(jīng)常出現(xiàn)“超時(shí)時(shí)間已到。在操作完成之前超時(shí)時(shí)間已過或服務(wù)器未響應(yīng)?!钡腻e(cuò)誤。

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

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

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

2、如果數(shù)據(jù)量非常大,以上超時(shí)錯(cuò)誤仍然存在,則可以在數(shù)據(jù)庫創(chuàng)建鏈接時(shí)自定義延長數(shù)據(jù)庫執(zhí)行超時(shí)時(shí)間,并參考以下代碼段:

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

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

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

      connection.Close();
    }
}

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

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